EasyExcel 对于excel文件的读取与显示

介绍

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()方法为表格的名称

具体的结果如图

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EasyExcel是一款基于Java的开源工具,用于读取和写入Excel文件。它提供了简单易用的API,可以方便地进行Excel文件的读写操作。 使用EasyExcel读取Excel文件非常简单,只需按照以下步骤进行操作: 1. 引入EasyExcel的依赖包。 2. 创建一个Java类,作为数据模型,用于存储读取到的Excel数据。 3. 使用EasyExcel提供的API,打开Excel文件读取数据。 4. 将读取到的数据存储到数据模型中。 5. 关闭Excel文件。 以下是使用EasyExcel读取Excel文件的示例代码: ```java // 引入EasyExcel的依赖包 import com.alibaba.excel.EasyExcel; // 创建数据模型类 public class ExcelData { private String name; private int age; // 其他属性... // getter和setter方法... } // 读取Excel文件 public class ReadExcel { public static void main(String[] args) { // Excel文件路径 String filePath = "path/to/excel/file.xlsx"; // 使用EasyExcel提供的API,打开Excel文件读取数据 EasyExcel.read(filePath, ExcelData.class, new ExcelDataListener()).sheet().doRead(); } } // 自定义监听器类,用于处理读取到的数据 public class ExcelDataListener extends AnalysisEventListener<ExcelData> { // 重写父类的方法,处理每一行读取到的数据 @Override public void invoke(ExcelData data, AnalysisContext context) { // 将读取到的数据存储到数据模型中,可以进行自定义操作 System.out.println("Name: " + data.getName()); System.out.println("Age: " + data.getAge()); // 其他操作... } // 重写父类的方法,读取完成后的操作 @Override public void doAfterAllAnalysed(AnalysisContext context) { // 关闭Excel文件等资源 } } ``` 以上就是使用EasyExcel读取Excel文件的简单介绍和示例代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值