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


相关文章
|
8天前
|
前端开发
react框架对Excel文件进行上传和导出
react框架对Excel文件进行上传和导出
|
9天前
|
前端开发
React实现一个excel文件导出
React实现一个excel文件导出
13 0
分享:2秒快速查询40万手机号码归属地,批量手机号码归属地查询可以导出excel表格,WPS表格查询手机号码归属地怎么操作,批量手机号码归属地批量查询软件,批量号码查询按省份和城市分类,按运移动号码电信号码联通号码分类整理
本文介绍了如何批量快速查询手机号码归属地并进行分类。首先,通过提供的百度网盘或腾讯云盘链接下载免费查询软件。其次,开启软件,启用复制粘贴功能,直接粘贴号码列表并选择高速查询。软件能在极短时间内(如1.76秒内)完成40多万个号码的查询,结果包括归属地、运营商、邮箱和区号,且数据准确。之后,可直接导出数据至表格,若数据超过100万,可按省份、城市及运营商分类导出。文章还附带了操作动画演示,展示全程流畅的处理大量手机号码归属地查询的过程。
分享:2秒快速查询40万手机号码归属地,批量手机号码归属地查询可以导出excel表格,WPS表格查询手机号码归属地怎么操作,批量手机号码归属地批量查询软件,批量号码查询按省份和城市分类,按运移动号码电信号码联通号码分类整理
|
19天前
|
文字识别
分享:如何ocr识别身份证复印件并导出至excel表格 ? 图片批量识别导出excel表格应用,图片批量识别转excel表格的方法
该软件是一款OCR身份证识别工具,能批量处理图片,自动提取身份证信息并导出为Excel。支持百度网盘和腾讯云盘下载。用户界面直观,操作简单,适合新手。识别过程包括:打开图片、一键识别、导出结果。特别注意,此程序仅适用于身份证识别,不适用于其他类型的图片识别。
分享:如何ocr识别身份证复印件并导出至excel表格 ? 图片批量识别导出excel表格应用,图片批量识别转excel表格的方法
|
30天前
|
easyexcel
【EasyExcel】第二篇:导出excel文件,导出多个sheet工作空间
【EasyExcel】第二篇:导出excel文件,导出多个sheet工作空间
|
30天前
|
SQL 数据库连接 数据库
【SQL Server】2. 将数据导入导出到Excel表格当中
【SQL Server】2. 将数据导入导出到Excel表格当中
55 0
|
30天前
|
JavaScript 前端开发
【导出Excel】Vue实现导出下载Excel文件(blob文件流)--亲测可用
【导出Excel】Vue实现导出下载Excel文件(blob文件流)--亲测可用
【导出Excel】Vue实现导出下载Excel文件(blob文件流)--亲测可用
|
24天前
|
前端开发 Java
基于Java爬取微博数据(二) 正文长文本+导出数据Excel
【5月更文挑战第12天】基于Java爬取微博数据,正文长文本+导出数据Excel
|
30天前
|
Java
java导出复杂excel
java导出复杂excel
|
26天前
|
JSON Rust 前端开发
【sheetjs】纯前端如何实现Excel导出下载和上传解析?
本文介绍了如何使用`sheetjs`的`xlsx`库在前端实现Excel的导出和上传。项目依赖包括Vite、React、SheetJS和Arco-Design。对于导出,从后端获取JSON数据,通过`json_to_sheet`、`book_new`和`writeFile`函数生成并下载Excel文件。对于上传,使用`read`函数将上传的Excel文件解析为JSON并发送至后端。完整代码示例可在GitHub仓库[fullee/sheetjs-demo](https://github.com/fullee/sheetjs-demo)中查看。
67 10