EasyExcel完成excel文件的导入导出
简介
【EasyExcel完成excel文件的导入导出】 常见的Excel分析框架有Apache poi 和EasyExcel, poi在另一篇已经介绍过了,详情可以看[https://www.cnblogs.com/jasmine-e/p/16064518.html]。
这篇主要针对EasyExcel,它是阿里巴巴开源的一个excel处理框架,使用简单,节省内存。解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析,因此大大减少占用内存。官网:[https://github.com/alibaba/easyexcel]。
入门案例
一、导入pom依赖
com.alibaba
easyexcel
2.1.7
org.slf4j
slf4j-simple
1.7.5
org.apache.xmlbeans
xmlbeans
3.1.0
org.projectlombok
lombok
1.18.12
junit
junit
4.12
二、创建实体类
@Data
public class ExcelStudentDTO {@ExcelProperty("姓名")
private String name;
@ExcelProperty("生日")
private Date birthday;
@ExcelProperty("薪资")
private Double salary;
}
三、导出excel
public class ExcelWriteTest {
@Test
public void simpleWriteXlsx() {
String fileName = "d:/excel/simpleWrite.xlsx";
//需要提前新建目录
// 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭
EasyExcel.write(fileName, ExcelStudentDTO.class).sheet("模板").doWrite(data());
}//辅助方法
private List data(){
List list = new ArrayList<>();
//算上标题,做多可写65536行
//超出:java.lang.IllegalArgumentException: Invalid row number (65536) outside allowable range (0..65535)
for (int i = 0;
i < 65535;
i++) {
ExcelStudentDTO data = https://www.it610.com/article/new ExcelStudentDTO();
data.setName("Helen" + i);
data.setBirthday(new Date());
data.setSalary(123456.1234);
list.add(data);
}return list;
}
}
四、读取Excel - 创建监听器
@Slf4j
public class ExcelStudentDTOListener extends AnalysisEventListener {/**
* 这个每一条数据解析都会来调用
*/
@Override
public void invoke(ExcelStudentDTO data, AnalysisContext context) {
log.info("解析到一条数据:{}", data);
}/**
* 所有数据解析完成了 都会来调用
*/
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
log.info("所有数据解析完成!");
}
}
- 读取数据
public class ExcelReadTest {/**
* 最简单的读
*/
@Test
public void simpleReadXlsx() {String fileName = "d:/excel/simpleWrite.xlsx";
// 这里默认读取第一个sheet
EasyExcel.read(fileName, ExcelStudentDTO.class, new ExcelStudentDTOListener()).sheet().doRead();
}@Test
public void simpleReadXls() {String fileName = "d:/excel/simpleWrite.xls";
EasyExcel.read(fileName, ExcelStudentDTO.class, new ExcelStudentDTOListener()).excelType(ExcelTypeEnum.XLS).sheet().doRead();
}
}
推荐阅读
- 小程序完成后的自我总结(一)
- JavaWeb学习记录——servlet+tomcat+request+respond+JSP实战项目(使用MVC模式开发)
- Excel批量转Word
- 实战演练!手把手教你完成仪表盘设计
- C#|C# 将CSV转为Excel
- 前端导出excel
- 毕业设计系列|毕设讲解之 --- 如何完成小程序毕业设计
- python读取excel画折线图_python读取excel数据绘制简单曲线图的完整步骤记录
- 音视频基础+ffmpeg原理+项目实战一课完成音视频技术开发入门
- java|(微信定时发送消息)一个java文件,完成可配置的微信定时任务