java文件下载接口_Java 导入数据到Excel并提供文件下载接口

我们需要用到 jxl 包的类,而 jxl.jar 正是操作 excel 表格的工具类库,除了 jxl 以外,poi 包也是一个 操作 excel 的类库。

而对比两个包,jxl 更适用与数据量大的情况,而 poi 在数据量不高(大约5000以内)时,效率较高,但占用内存大,更容易内存溢出。

测试数据

private int id;

private String name;

private int age;

private String gender;

public List getPersonList() {

List list = new ArrayList<>();

list.add(new Person(1, "Howie", 20, "female"));

list.add(new Person(2, "Wade", 25, "male"));

list.add(new Person(3, "Duncan", 30, "male"));

list.add(new Person(4, "Kobe", 35, "male"));

list.add(new Person(5, "James", 40, "male"));

return list;

}

1. 将数据全部导入到一张表格

//创建文件本地文件

//直接将文件创建在项目目录中

String filePath = "人员数据.xlsx";

File dbfFile = new File(filePath);

//使用 Workbook 类的工厂方法创建一个可写入的工作薄(Workbook)对象

WritableWorkbook wwb = Workbook.createWorkbook(dbfFile);

//如果文件不存在,则创建一个新的文件

if (!dbfFile.exists() || dbfFile.isDirectory()) {

dbfFile.createNewFile();

}

//获得人员信息 list (PersonFactroy 类已经被依赖注入)

List list = personFactroy.getPersonList();

//创建一个可写入的工作表

WritableSheet ws = wwb.createSheet("列表 1", 0);

//添加excel表头

ws.addCell(new Label(0, 0, "序号"));

ws.addCell(new Label(1, 0, "姓名"));

ws.addCell(new Label(2, 0, "年龄"));

ws.addCell(new Label(3, 0, "性别"));

int index = 0;

for (Person person : list) {

//将生成的单元格添加到工作表中

//(这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行)

ws.addCell(new Label(0, index + 1, String.valueOf(person.getId())));

ws.addCell(new Label(1, index + 1, person.getName()));

ws.addCell(new Label(2, index + 1, String.valueOf(person.getAge())));

ws.addCell(new Label(3, index + 1, person.getGender()));

index++;

}

format,png

2. 将数据导入到多个表格

//前面的代码一致

//每个工作表格最多存储2条数据(注:excel表格一个工作表可以存储65536条)

int mus = 2;

//数据的总大小

int totle = list.size();

//总表格数

int avg = totle / mus + 1;

for (int i = 0; i < avg; i++) {

//创建一个可写入的工作表

WritableSheet ws = wwb.createSheet("列表" + (i + 1), i);

//添加excel表头

ws.addCell(new Label(0, 0, "序号"));

ws.addCell(new Label(1, 0, "姓名"));

ws.addCell(new Label(2, 0, "年龄"));

ws.addCell(new Label(3, 0, "性别"));

int num = i * mus;

int index = 0;

for (int m = num; m < list.size(); m++) {

//判断index == mus的时候跳出当前for循环

if (index == mus) {

break;

}

Person person = list.get(m);

//将生成的单元格添加到工作表中

//(这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行)

ws.addCell(new Label(0, index + 1, String.valueOf(person.getId())));

ws.addCell(new Label(1, index + 1, person.getName()));

ws.addCell(new Label(2, index + 1, String.valueOf(person.getAge())));

ws.addCell(new Label(3, index + 1, person.getGender()));

index++;

}

}

这里是根据每个表的数据量来分,大家也可以根据其中一个属性等等来分成各个表格

format,png

format,png

提供文件下载接口

该方法利用文件流来写入文件,方法类型为 void,不需要 return,除此之外,接口参数中需要添加上 HttpServletResponse

@RequestMapping(value = "/getExcel", method = RequestMethod.GET)

public void createBoxListExcel(HttpServletResponse response) throws Exception {

String filePath = "人员数据.xlsx";

/**

* 这部分是刚刚导入 Excel 文件的代码,省略

*/

String fileName = new String("人员数据.xlsx".getBytes(), "ISO-8859-1");

//设置文件名

response.addHeader("Content-Disposition", "filename=" + fileName);

OutputStream outputStream = response.getOutputStream();

FileInputStream fileInputStream = new FileInputStream(filePath);

byte[] b = new byte[1024];

int j;

while ((j = fileInputStream.read(b)) > 0) {

outputStream.write(b, 0, j);

}

fileInputStream.close();

outputStream.flush();

outputStream.close();

}

然后,我们直接在地址栏输入localhost:8080/getExcel既可立刻下载你的文件

注意: String fileName = new String("人员信息.xlsx".getBytes(), "ISO-8859-1"); 我使用了 ISO-8859-1 编码,原因是 ISO-8859-1编码是单字节编码,向下兼容 ASCII,而 Header 中只支持 ASCII,传输的文件名必须是 ASCII

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值