EasyExcel导出Excel表格到浏览器,通过Postman测试导出Excel
csdh11 2025-03-10 14:36 1 浏览
一、前言
小编最近接到一个导出Excel的需求,需求还是很简单的,只需要把表格展示的信息导出成Excel就可以了,也没有复杂的合并列什么的。
常见的导出Excel的技术:
- hutool
- easyExcel
- poi
hutool和easyExcel都是对poi的封装,使用起来更加方便!由于公司都是使用EasyExcel进行导出,小编也不能特立独行。如果想看poi和hutool导出的可以看一下小编的之前写的文章:
使用POI+hutool导入Excel并把内容添加到数据库中,直接可以用!!!_掉发的小王的博客-CSDN博客_poi导入excel到数据库
使用POI把查询到的数据表数据导出到Excel中,一个表一个sheet.最详细!!!_掉发的小王的博客-CSDN博客_poi把数据导出到excel
话不多说,咱们直接开始。
二、导入Maven依赖
com.alibaba
easyexcel
3.0.5
特别注意:
这里的版本应该适当高一些,不然我们在导出时有日期是jdk8新特性LocalDateTime,会不支持的!
小编开始用的同事以前使用的2.几版本就出现不支持的问题,大家小心哈!!
三、编写导出实体类
@Data
@ColumnWidth(20)
public class Test implements Serializable {
private static final long serialVersionUID = 337361630075002456L;
@TableId(type= IdType.ASSIGN_ID)
@ExcelProperty(value = "id",index = 0)
private long id;
@ExcelProperty(value = "名字",index = 1)
private String name;
@ExcelProperty(value = "性别",index = 2)
private String gender;
@ExcelProperty(value = "数据",index = 3)
private String data;
@ExcelProperty(value = "创建时间",index = 4)
private LocalDateTime createDate;
@ExcelProperty(value = "更新时间",index = 5)
private LocalDateTime updateDate;
}
参数解读:
@ExcelProperty:加在需要导出的字段上,value是导出表头展示的内容,如果不写则会按照字段名字来当做表头。
经过小编测试:导出的实体类,不加这个注解也会导出,不过表头为字段名字!!
@ColumnWidth(20):设置每一个表头的长度,加载类上就是全部都是这个长度,加在字段上就是一个表头的长度!
如果你需要合并的话,需要自己指定策略,继承extends AbstractCellWriteHandler 重写afterCellDispose,就可以了;这里小编就不展示了,等后面有这个需求在给大家详细教学一下哈!!
四、测试
小编为了方便直接在controller里完成了,大家不要学哈,业务在service里写比较规范哈!
@RestController
@RequestMapping("/test")
@Slf4j
@RequiredArgsConstructor
public class TestController {
private final TestService testService;
@NonNull
private TestMapper testMapper;
@SneakyThrows
@GetMapping("/easyExcel")
public void easyExcel (HttpServletResponse response){
String fileName = new String("导出excel.xlsx".getBytes(), StandardCharsets.ISO_8859_1);
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding("utf8");
response.setHeader("Content-disposition", "attachment;filename=" + fileName );
List list = testMapper.selectList(null);
ServletOutputStream outputStream = response.getOutputStream();
EasyExcel.write(outputStream, Test.class)
.sheet("sheet1")
.doWrite(list);
}
}
如果对@RequiredArgsConstructor不了解的可以看一下小编的这篇文章!
还在使用@Autowrired注入?不妨试试@RequiredArgsConstructor注解完美替代_掉发的小王的博客-CSDN博客
五、浏览器测试
我们现在浏览器里访问,地址:
http://localhost:8089/test/easyExcel
六、Postman测试
提醒:
通常情况下我们在企业级开发时,都是需要登录验证的,这时我们无法通过浏览器进行访问测试,这时我们需要使用Postman进行测试,开始小编导出的都是一推乱码,后来小伙伴告诉我,导出不能直接Send,要点击下面的Send And Download。现在给大家演示一下哈:
七、查看导出文件
我们可以看到没有乱码哈!
八、总结
我们这样就完成了测试,成功的导出了Excel。本篇只是简单的进行导出测试,可能你们的需求要美化,详细参考官网:EasyExcel · 语雀
有缘人才可以看得到的哦!!!
相关推荐
- Hutool Java工具类库导出Excel,超级简单
-
作者:程序猿的内心独白原文链接:http://suo.im/5Zxx2L前言在开发应用系统的时候,导出文件是必不可放的功能。以前用过POI、easyexcel等工具的导入导出功能,但总感觉太麻烦了,代...
- java轻松玩转Excel之EasyExcel
-
项目地址:https://github.com/PiKeZhao/excel-model.git如果您对该项目有什么问题加群咨询哦978219630(各类电子书籍,学习视频等)大家常用Apache...
- 程序员:超级简单导出Excel 工具,Hutool Java工具类库
-
前言在开发应用系统的时候,导出文件是必不可放的功能。以前用过POI、easyexcel等工具的导入导出功能,但总感觉太麻烦了,代码特别多,感觉并不是很好用。今天给大家介绍一款新工具,java工具类库H...
- EasyExcel导出Excel表格到浏览器,通过Postman测试导出Excel
-
一、前言小编最近接到一个导出Excel的需求,需求还是很简单的,只需要把表格展示的信息导出成Excel就可以了,也没有复杂的合并列什么的。...
- 好难~记录一次生产上的OOM解决过程
-
点击上方,轻松关注!及时获取有趣有料的技术文章记录一次生产上的OOM解决过程一.项目架构...
- 发现开源:替换Jenkins,支持多用户多语言部署平台Walle很震撼
-
溪云阁:专注编程教学,架构,JAVA,Python,微服务,机器学习等领域,欢迎关注,一起学习。部署系统,从手动部署,到用jenkins,到阿里的自动化运维部署,一直在不断的变化姿势,好让自己舒服点。...
- SpringBoot + EasyExcel 轻松实现百万级数据导入导出,用起来还优雅
-
01、背景介绍在实际的业务系统开发过程中,操作Excel实现数据的导入导出基本上是个非常常见的需求。...
- 10W 行级别数据的 Excel 导入优化记录
-
优质文章,及时送达作者:后青春期的Keatswww.cnblogs.com/keatsCoder/p/13217561.html需求说明项目中有一个Excel导入的需求:缴费记录导入...
- easypoi导出Excel根据内容如何自动换行和自动调整行高
-
在使用easypoi导出EXCEL的时候,经常会遇到需要根据内容自动换行和自动调整行高的情况...
- POI读取/生成Excel大文件,有高人吗?
-
最近在搞一个通用文件处理服务器,需要处理excel文件,但是有的excel文件大小超过3M,读取文件时直接导致jvm异常:gcoverheadlimitexceeded。原来poi读取excel...
- 如何轻松实现Excel动态列导出?Easypoi教程来袭!
-
EasyPoi简介EasyPoi是一款基于ApachePOI和jxls的Java开源框架,它可以用于快速创建Excel、Word、Pdf等复杂文档。Easypoi最大的特点是可以通过注解来实现对Ex...
- Excel导出,Excel模板导出Excel导入,Word模板导出神器-Easypoi
-
概述Easypoi是码云上的一个开源项目。项目开发组织是Lemur开源。目前属于码云最有价值开源项目。Easypoi是对poi的封装,其主打的功能就是容易,让一个没见接触过poi的人员就可以方便...
- 优雅地实现EasyPoi动态导出列的两种方式
-
前言嗨,大家好,我是希留。...
- easypoi一款方便快捷的excel处理框架,赶紧学习起来
-
easypoi是一个基于ApachePOI和jxls封装的Java框架,用于简化Excel导入导出和Word导出等操作。它支持将Java对象转换为Excel或Word文档,并支持Excel模板导出和...
- EasyPoi使用
-
EasyPoi的主要特点:1.设计精巧,使用简单2.接口丰富,扩展简单3.默认值多,writelessdomore4.springmvc支持,web导出可以简单明了使用1.easypoi...
- 一周热门
- 最近发表
-
- Hutool Java工具类库导出Excel,超级简单
- java轻松玩转Excel之EasyExcel
- 程序员:超级简单导出Excel 工具,Hutool Java工具类库
- EasyExcel导出Excel表格到浏览器,通过Postman测试导出Excel
- 好难~记录一次生产上的OOM解决过程
- 发现开源:替换Jenkins,支持多用户多语言部署平台Walle很震撼
- SpringBoot + EasyExcel 轻松实现百万级数据导入导出,用起来还优雅
- 10W 行级别数据的 Excel 导入优化记录
- easypoi导出Excel根据内容如何自动换行和自动调整行高
- POI读取/生成Excel大文件,有高人吗?
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 反恐24小时电话铃声 (33)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)