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

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

你可能感兴趣的:(JAVA,EXCEL操作,java,excel)