esayExcel完成文件导入导出&模板导出

本文介绍了如何使用阿里巴巴的easyExcel库在Java Web环境下进行异步文件下载和上传。在下载部分,文章提到需要在controller中添加查询条件,并解决了设置导出文件名的问题。在上传部分,通过监听类控制内存中的记录数并调用service将数据写入数据库。同时,文章还展示了如何利用easyExcel生成模板导出。
摘要由CSDN通过智能技术生成

easyExcel是阿里的几位程序员写的一个快速解析excel的包,可以点开网站参考一下,其实这篇文章也就是里边的重写。

因为我做的是web下的上传下载,所以走的是异步方式,先看比较简单一点的下载吧:

下载

controller.java

这里如果要补充的话,就是加一个查询条件。
还有一个比较困惑的地方是怎么修改导出的文件名?,修改了header里的filename似乎没用的样子。

	@SneakyThrows
	@GetMapping("/export-Device")
	public void exportDevice(@ApiIgnore @RequestParam Map<String, Object> Device,  HttpServletResponse response) {
   
		QueryWrapper<Device> queryWrapper = Condition.getQueryWrapper(Device, Device.class);
		List<DeviceExcel> list = deviceService.exportDevice(queryWrapper);
		response.setContentType("application/vnd.ms-excel");
		response.setCharacterEncoding(Charsets.UTF_8.name());
		String fileName = URLEncoder.encode("设备数据导出", Charsets.UTF_8.name());
		System.out.println(fileName);
		response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
		EasyExcel.write(response.getOutputStream(), DeviceExcel.class).sheet("设备表").doWrite(list);
	}

excel类:

这里遇到一个坑,我自己写的时候没有加@data标签,导致对应的属性都没有get和set方法,一直读不到数据,加上@data标签之后就正常了。

@Data
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值