EasyExcel 的主要特点
1、高性能:EasyExcel 采用了异步导入导出的方式,并且底层使用 NIO 技术实现,使得其在导入导出大数据量时的性能非常高效。
2、易于使用:EasyExcel 提供了简单易用的 API,用户可以通过少量的代码即可实现复杂的 Excel 导入导出操作。
3、增强的功能“EasyExcel 支持多种格式的 Excel 文件导入导出,同时还提供了诸如合并单元格、数据校验、自定义样式等增强的功能。
4、可扩展性好:EasyExcel 具有良好的扩展性,用户可以通过自定义 Converter 对自定义类型进行转换,或者通过继承 EasyExcelListener 来自定义监听器实现更加灵活的需求。
maven坐标
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>3.1.0</version>
</dependency>
测试实体类
@Data
public class CategoryExcelVo {@ExcelProperty(value = "id" ,index = 0)
private Long id;@ExcelProperty(value = "名称" ,index = 1)
private String name;@ExcelProperty(value = "图片url" ,index = 2)
private String imageUrl ;@ExcelProperty(value = "上级id" ,index = 3)
private Long parentId;@ExcelProperty(value = "状态" ,index = 4)
private Integer status;@ExcelProperty(value = "排序" ,index = 5)
private Integer orderNum;
}
测试监听器
public class ExcelListener<T> extends AnalysisEventListener<T> {
//可以通过实例获取该值
private List<T> datas = new ArrayList<>();@Override
public void invoke(T o, AnalysisContext analysisContext) { // 每解析一行数据就会调用一次该方法
datas.add(o);//数据存储到list,供批量处理,或后续自己业务逻辑处理。
}public List<T> getDatas() {
return datas;
}@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
// excel解析完毕以后需要执行的代码
}
}
EasyExcel 读操作
读操作需要一个监听器
public class EasyExcelTest {
public static void main(String[] args) {
readDateToExcel();
}//读取方法
public static void readDateToExcel() {
String fileName = "D://分类数据.xlsx" ;
// 创建一个监听器对象
ExcelListener<CategoryExcelVo> excelListener = new ExcelListener<>();
EasyExcel.read(fileName, CategoryExcelVo.class, excelListener).sheet().doRead(); // 解析excel表格
List<CategoryExcelVo> excelVoList = excelListener.getDatas(); //获取解析到的数据
excelVoList.forEach(s -> System.out.println(s) ); // 进行遍历操作
}
}
EasyExcel 写操作
public class EasyExcelTest {
public static void main(String[] args) {
writeDataToExcel();
}public static void writeDataToExcel() {
List<CategoryExcelVo> list = new ArrayList<>() ;
list.add(new CategoryExcelVo(1L , "数码办公" , "",0L, 1, 1)) ;
list.add(new CategoryExcelVo(11L , "华为手机" , "",1L, 1, 2)) ;
EasyExcel.write("D://分类数据1.xlsx" , CategoryExcelVo.class).sheet("分类数据1").doWrite(list);
}
}