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