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


相关文章
|
20天前
|
Java 应用服务中间件
SpringBoot获取项目文件的绝对路径和相对路径
SpringBoot获取项目文件的绝对路径和相对路径
59 1
SpringBoot获取项目文件的绝对路径和相对路径
|
14天前
|
网络协议 Java
springboot配置hosts文件
springboot配置hosts文件
42 11
|
20天前
|
前端开发 Java easyexcel
SpringBoot操作Excel实现单文件上传、多文件上传、下载、读取内容等功能
SpringBoot操作Excel实现单文件上传、多文件上传、下载、读取内容等功能
60 8
|
19天前
|
存储 前端开发 JavaScript
|
19天前
|
存储 Java API
|
19天前
|
Java API Apache
|
23天前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
31 4
|
21天前
|
Java
SpringBoot获取文件将要上传的IP地址
SpringBoot获取文件将要上传的IP地址
30 0
|
1月前
|
数据采集 存储 JavaScript
自动化数据处理:使用Selenium与Excel打造的数据爬取管道
本文介绍了一种使用Selenium和Excel结合代理IP技术从WIPO品牌数据库(branddb.wipo.int)自动化爬取专利信息的方法。通过Selenium模拟用户操作,处理JavaScript动态加载页面,利用代理IP避免IP封禁,确保数据爬取稳定性和隐私性。爬取的数据将存储在Excel中,便于后续分析。此外,文章还详细介绍了Selenium的基本设置、代理IP配置及使用技巧,并探讨了未来可能采用的更多防反爬策略,以提升爬虫效率和稳定性。
|
3月前
|
关系型数据库 MySQL Shell
不通过navicat工具怎么把查询数据导出到excel表中
不通过navicat工具怎么把查询数据导出到excel表中
46 0