一、前言
小编最近接到一个导出Excel的需求,需求还是很简单的,只需要把表格展示的信息导出成Excel就可以了,也没有复杂的合并列什么的。
常见的导出Excel的技术:
- hutool
- easyExcel
- poi
hutool和easyExcel都是对poi的封装,使用起来更加方便!由于公司都是使用EasyExcel进行导出,小编也不能特立独行。如果想看poi和hutool导出的可以看一下小编的之前写的文章:
使用POI+hutool导入Excel
使用POI把查询到的数据表数据导出到Excel中,一个表一个sheet
话不多说,咱们直接开始。
二、导入Maven依赖
<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.0.5</version></dependency>
特别注意:
这里的版本应该适当高一些,不然我们在导出时有日期是jdk8新特性
LocalDateTime
,会不支持的!
小编开始用的同事以前使用的
2.几
版本就出现不支持的问题,大家小心哈!!
三、编写导出实体类
@Data@ColumnWidth(20)publicclassTestimplementsSerializable{privatestaticfinallong serialVersionUID =337361630075002456L;@TableId(type=IdType.ASSIGN_ID)@ExcelProperty(value ="id",index =0)privatelong id;@ExcelProperty(value ="名字",index =1)privateString name;@ExcelProperty(value ="性别",index =2)privateString gender;@ExcelProperty(value ="数据",index =3)privateString data;@ExcelProperty(value ="创建时间",index =4)privateLocalDateTime createDate;@ExcelProperty(value ="更新时间",index =5)privateLocalDateTime updateDate;}
参数解读:
@ExcelProperty
:加在需要导出的字段上,
value
是导出表头展示的内容,如果不写则会按照字段名字来当做表头。
经过小编测试:导出的实体类,不加这个注解也会导出,不过表头为字段名字!!
@ColumnWidth(20)
:设置每一个表头的长度,加载类上就是全部都是这个长度,加在字段上就是一个表头的长度!
如果你需要合并的话,需要自己指定策略,继承
extends AbstractCellWriteHandler
重写
afterCellDispose
,就可以了;这里小编就不展示了,等后面有这个需求在给大家详细教学一下哈!!
四、测试
小编为了方便直接在controller里完成了,大家不要学哈,业务在service里写比较规范哈!
@RestController@RequestMapping("/test")@Slf4j@RequiredArgsConstructorpublicclassTestController{privatefinalTestService testService;@NonNullprivateTestMapper testMapper;@SneakyThrows@GetMapping("/easyExcel")publicvoid easyExcel (HttpServletResponse response){String fileName =newString("导出excel.xlsx".getBytes(),StandardCharsets.ISO_8859_1);
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding("utf8");
response.setHeader("Content-disposition","attachment;filename="+ fileName );List<Test> list = testMapper.selectList(null);ServletOutputStream outputStream = response.getOutputStream();EasyExcel.write(outputStream,Test.class).sheet("sheet1").doWrite(list);}}
如果对@RequiredArgsConstructor不了解的可以看一下小编的这篇文章!@RequiredArgsConstructor代替@Autowrired
五、浏览器测试
我们现在浏览器里访问,地址:
http://localhost:8089/test/easyExcel
六、Postman测试
提醒:通常情况下我们在企业级开发时,都是需要登录验证的,这时我们无法通过浏览器进行访问测试,这时我们需要使用Postman进行测试,开始小编导出的都是一推乱码,后来小伙伴告诉我,导出不能直接
Send
,要点击下面的
Send And Download
。现在给大家演示一下哈:
七、查看导出文件
我们可以看到没有乱码哈!
八、总结
我们这样就完成了测试,成功的导出了Excel。本篇只是简单的进行导出测试,可能你们的需求要美化,详细参考官网:easyExcel官网
有缘人才可以看得到的哦!!!
点击访问!小编自己的网站,里面也是有很多好的文章哦!
版权归原作者 掉发的小王 所有, 如有侵权,请联系我们删除。