SpringBoot如何用easyPOI导出excel文件

简介: 在工作中,经常需要我们用Java代码导出一些数据,保存在Excel中。这是非常实用的Excel导出功能,如果我们用SpringBoot结合EasyPOI框架,可以非常方便地实现这个功能。

在工作中,经常需要我们用Java代码导出一些数据,保存在Excel中。这是非常实用的Excel导出功能,如果我们用SpringBoot结合EasyPOI框架,可以非常方便地实现这个功能。


在maven项目中,添加easyPOI的支持

b57ffc97c8fb40668edabb571f8c53ee.png


打开项目的pom文件,在dependencies节点中添加easypoi框架的依赖。


<!-- poi -->


<dependency>


           <groupId>cn.afterturn</groupId>


           <artifactId>easypoi-base</artifactId>


           <version>3.0.3</version>


       </dependency>


       <dependency>


           <groupId>cn.afterturn</groupId>


           <artifactId>easypoi-web</artifactId>


           <version>3.0.3</version>


       </dependency>


       <dependency>


           <groupId>cn.afterturn</groupId>


           <artifactId>easypoi-annotation</artifactId>


           <version>3.0.3</version>


       </dependency>


请耐心等待jar包的下载。


创建需要导出的类别


意思就是,比如说你要导出一个图书列表,那么每一个图书的信息必然是对应Java中的某一个类的实例。那么,Excel中的一个图书列表,对应Java中的ArrayList<Book>


e80e99e584ec4498bc6d1f0fe838e9ff.png


8e3cdbdf5c8b47b1b0c0a119189f48cc.png


以上是书本类的最初版本,接下来,如果我们要导出Excel的话,我们还需要设置书本Book类中的属性分别在Excel中的第几列?


在easypoi框架,我们依然用注解的方式去设置属性在excel中的第几列。



@Excel(name="书本编号", orderNum = "0")


private String no;


我们需要给实体类中的每一个属性上面打一个@Excel注解,然后在这个注解右边写一个圆括号,再在圆括号中设置当前属性在Excel表头名称和列号。

828cc889527f4b938cbe088ba865d15d.png

设置好属性后,再生成对应的get,set方法。

编写导出Excel的接口exportBooks

58a5789ec7cb4ea186ba6fea2fc383df.png

c3b1b8499352437ebbdce51cdcc08d7f.png

先测试能否访问这个接口。


接口调通以后,用ArrayList去装一本书:


Book b1 = new Book();


b1.setNo("Book001");


b1.setName("汤姆索亚历险记");


b1.setAuthor("马克吐温");


b1.setPrice(28.8);


List books = new ArrayList<Book>();


books.add(b1);


接下来要做Excel的导出,说白了,就是把你刚才新建的ArrayList对象,根据一定的格式直接保存为一个Excel文件。


这边需要用到一个PoiUtils工具类,把这个类放在你的项目中即可。


1e650249d7914c238d5ea03d90b74c2e.png

最后,注意方法不能有返回值,改为void,防止IO流冲突。

3eda48d38bde4af999171edb79cbaf48.png


相关文章
|
2月前
|
XML 前端开发 Java
基于SpringBoot 3.3实现任意文件在线预览功能的技术分享
【8月更文挑战第30天】在当今的数字化办公环境中,文件在线预览已成为提升工作效率、优化用户体验的重要功能之一。无论是文档、图片、PDF还是代码文件,用户都期望能够直接在浏览器中快速查看而无需下载。本文将围绕如何在Spring Boot 3.3框架下实现这一功能,分享一系列技术干货,助力开发者高效构建文件预览服务。
150 2
|
19小时前
|
数据处理 Python
Python 高级技巧:深入解析读取 Excel 文件的多种方法
在数据分析中,从 Excel 文件读取数据是常见需求。本文介绍了使用 Python 的三个库:`pandas`、`openpyxl` 和 `xlrd` 来高效处理 Excel 文件的方法。`pandas` 提供了简洁的接口,而 `openpyxl` 和 `xlrd` 则针对不同版本的 Excel 文件格式提供了详细的数据读取和处理功能。此外,还介绍了如何处理复杂格式(如合并单元格)和进行性能优化(如分块读取)。通过这些技巧,可以轻松应对各种 Excel 数据处理任务。
27 16
|
2天前
|
Java 关系型数据库 数据库连接
SpringBoot项目使用yml文件链接数据库异常
【10月更文挑战第3天】Spring Boot项目中数据库连接问题可能源于配置错误或依赖缺失。YAML配置文件的格式不正确,如缩进错误,会导致解析失败;而数据库驱动不匹配、连接字符串或认证信息错误同样引发连接异常。解决方法包括检查并修正YAML格式,确认配置属性无误,以及添加正确的数据库驱动依赖。利用日志记录和异常信息分析可辅助问题排查。
22 10
|
4天前
|
存储 前端开发 Java
Spring Boot 集成 MinIO 与 KKFile 实现文件预览功能
本文详细介绍如何在Spring Boot项目中集成MinIO对象存储系统与KKFileView文件预览工具,实现文件上传及在线预览功能。首先搭建MinIO服务器,并在Spring Boot中配置MinIO SDK进行文件管理;接着通过KKFileView提供文件预览服务,最终实现文档管理系统的高效文件处理能力。
|
1天前
|
Java 关系型数据库 MySQL
SpringBoot项目使用yml文件链接数据库异常
【10月更文挑战第4天】本文分析了Spring Boot应用在连接数据库时可能遇到的问题及其解决方案。主要从四个方面探讨:配置文件格式错误、依赖缺失或版本不兼容、数据库服务问题、配置属性未正确注入。针对这些问题,提供了详细的检查方法和调试技巧,如检查YAML格式、验证依赖版本、确认数据库服务状态及用户权限,并通过日志和断点调试定位问题。
|
17天前
R Excel 文件
Excel 格式的文件主要是 xls 或 xlsx,这两种文件可以在 R 语言中导入 xlsx 库来实现直接的读取。
53 23
|
6天前
|
前端开发 Java easyexcel
SpringBoot操作Excel实现单文件上传、多文件上传、下载、读取内容等功能
SpringBoot操作Excel实现单文件上传、多文件上传、下载、读取内容等功能
14 6
|
7天前
|
Java
SpringBoot获取文件将要上传的IP地址
SpringBoot获取文件将要上传的IP地址
21 6
5-22|pywintypes.com_error: (-2147352567, '发生意外。', (0, 'Microsoft Office Excel', 'Excel 无法打开文件“
5-22|pywintypes.com_error: (-2147352567, '发生意外。', (0, 'Microsoft Office Excel', 'Excel 无法打开文件“
|
2月前
|
SQL JSON 关系型数据库
n种方式教你用python读写excel等数据文件
n种方式教你用python读写excel等数据文件
下一篇
无影云桌面