文章目录
使用EasyExcel读取Excel
一、关于EasyExcel
EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。
- github地址:https://github.com/alibaba/easyexcel,
- 国内官网文档地址:https://www.yuque.com/easyexcel/doc/easyexcel
<!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.2.6</version>
</dependency>
二、读取excel
- 创建实体类
- 创建监听器
- 开始读取
实体类
@Data
public class Region {
private Integer id;
private String province;
private String city;
}
本地读取
/**
* 最简单的读
* <p>1. 创建excel对应的实体对象 参照{@link DemoData}
* <p>2. 由于默认一行行的读取excel,所以需要创建excel一行一行的回调监听器,参照{@link DemoDataListener}
* <p>3. 直接读即可
*/
@Test
public void simpleRead() {
// 有个很重要的点 DemoDataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
String fileName = "D:\\project\\地区列表.xlsx";
// 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
EasyExcel.read(fileName, Region.class, new DemoDataListener()).sheet(