0


EasyExcel导出Excel表格到浏览器,并通过Postman测试导出Excel【入门案例】

一、前言

小编最近接到一个导出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官网


有缘人才可以看得到的哦!!!

点击访问!小编自己的网站,里面也是有很多好的文章哦!


本文转载自: https://blog.csdn.net/qq_52423918/article/details/124925036
版权归原作者 掉发的小王 所有, 如有侵权,请联系我们删除。

“EasyExcel导出Excel表格到浏览器,并通过Postman测试导出Excel【入门案例】”的评论:

还没有评论