介绍

EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节省内存著称。EasyExcel能大大减少占用内存的主要原因是在解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。

官网地址:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel

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;
}

首先是读操作

首先先创建一个监听器 例如 ExcelListener 其中必须继承 AnalysisEventListener 并且实现其中的 invoke(),doAfterAllAnalysed()方法

public class ExcelListener<T> extends AnalysisEventListener<T> {
​
    private List<T> data = new ArrayList<>();
​
    //读取excel内容
    //从第二行开始读取,把每行内容封装到t对象里面
    @Override
    public void invoke(T t, AnalysisContext analysisContext) {
        data.add(t);
    }
​
    public List<T> getData(){
        return data;
    }
​
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
​
    }
}

读操作 (其中CategoryExcelVo是我自己创建的实体类,包含表格中的列,只不过好像影响不大)

//读操作
public static void read(){
    //读取excel文件内容
    String fileName = "G://test.xlsx";
    //调用方法
    ExcelListener<CategoryExcelVo> excelListener = new ExcelListener();
    EasyExcel.read(fileName, CategoryExcelVo.class,excelListener).sheet().doRead();
    List<CategoryExcelVo> data = excelListener.getData();
    System.out.println(data);
}

读取文件

读取结果

[
 CategoryExcelVo(id=1, name=2, imageUrl=3, parentId=4, status=5, orderNum=6), 
 CategoryExcelVo(id=12, name=22, imageUrl=33, parentId=44, status=55, orderNum=66),
 CategoryExcelVo(id=31, name=null, imageUrl=null, parentId=null, status=null, orderNum=null)
]

接下来的是写操作

//写操作
public static void write(){
    ArrayList<CategoryExcelVo> list = new ArrayList<>();
    list.add(new CategoryExcelVo(1L , "数码办公" , "",0L, 1, 1)) ;
    list.add(new CategoryExcelVo(11L , "华为手机" , "",1L, 1, 2)) ;
    EasyExcel.write("G://test2.xlsx",CategoryExcelVo.class).sheet("分类的数据").doWrite(list);
}

其中wirte方法中

ExcelWriterBuilder write(String pathName, Class head)

第一个为文件路径,第二个为表头第一行的名称,我的为CategoryExcelVo中的实体类

.sheet()方法为表格的名称

具体的结果如图

GitHub 加速计划 / ea / easyexcel
18
5
下载
快速、简洁、解决大文件内存溢出的java处理Excel工具
最近提交(Master分支:7 个月前 )
c42183df Bugfix 7 个月前
efa7dff6 * 重新加回 `commons-io` 7 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐