EasyExcel轻松读取Excel文件!

这篇具有很好参考价值的文章主要介绍了EasyExcel轻松读取Excel文件!。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

EasyExcel是一个Java库,用于快速、简单地读写Excel文件。要使用EasyExcel,您首先需要将其添加为项目的依赖:

如果使用Maven,可以添加以下依赖项:

<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>easyexcel</artifactId>
  <version>2.2.7</version>
</dependency>

一下几种方式读取文件

1、EasyExcel.read()

例如,下面的代码演示了如何使用EasyExcel读取一个Excel文件中的数据:

// 创建一个ExcelReader对象,用于读取Excel文件
ExcelReader reader = EasyExcel.read("/path/to/file.xlsx", MyModel.class, new MyListener())
    .build();

// 读取Excel文件中的数据
reader.read();

// 关闭reader
reader.finish();

在上面的代码中,MyModel.class指定了用于表示Excel文件中的数据的Java类,而MyListener类实现了一个事件监听器,用于处理读取过程中发生的事件。

下面的代码演示了如何使用EasyExcel将数据写入Excel文件:

// 创建一个ExcelWriter对象,用于写入Excel文件
ExcelWriter writer = EasyExcel.write("/path/to/file.xlsx", MyModel.class)

2、ExcelReader.read()

可以通过为ExcelReader.read()方法传递一个List对象来读取Excel文件中的数据并存储到一个集合中。例如:

// 创建一个用于存储数据的List
List<MyModel> data = new ArrayList<>();

// 创建一个ExcelReader对象,用于读取Excel文件
ExcelReader reader = EasyExcel.read("/path/to/file.xlsx", MyModel.class, new MyListener())
    .build();

// 读取Excel文件中的数据
reader.read(data);

// 关闭reader
reader.finish();

// 在这里,data中存储了读取出来的数据

在上面的代码中,ExcelReader.read()方法会将读取到的数据添加到传入的List对象中。可以在读取完成后使用该集合进行进一步的操作。

3、实现ExcelListener

在EasyExcel中,您可以通过实现ExcelListener接口来创建一个监听器,用于在读取Excel文件中的数据时处理事件。例如,下面的代码演示了如何实现一个监听器:

public class MyListener implements ExcelListener {

  // 在读取Excel开始时调用
  @Override
  public void onStart(ExcelReaderContext context) {
    // do something
  }

  // 在读取完一行数据后调用
  @Override
  public void onRow(ExcelReaderContext context) {
    // do something
  }

  // 在读取完所有数据后调用
  @Override
  public void onFinish(ExcelReaderContext context) {
    // do something
  }

}

在上面的代码中,MyListener类实现了ExcelListener接口,并重写了接口中定义的三个方法。在读取Excel文件时,EasyExcel会在适当的时候调用这些方法,您可以在这些方法中处理事件。

例如,您可以在onRow()方法中处理读取完一行数据后的事件,并在onFinish()方法中处理读取完所有数据后的事件。

下面的代码演示了如何使用一个监听器读取Excel文件中的数据:

// 创建一个ExcelReader对象,用于读取Excel文件
ExcelReader reader = EasyExcel.read("/path/to/file.xlsx", MyModel.class, new MyListener())
    .build();

// 读取Excel文件中的数据
reader.read();

// 关闭reader
reader.finish();

4、实现AnalysisEventListener

除了实现ExcelListener接口和使用回调函数,EasyExcel还提供了另一种方式来处理读取Excel文件中的数据:继承AnalysisEventListener类。

AnalysisEventListener是一个抽象类,它实现了ExcelListener接口,并为每一行数据提供了一个默认的实现。您可以继承AnalysisEventListener类,并重写其中的方法来实现您自己的监听器。

例如,下面的代码演示了如何继承AnalysisEventListener类来实现一个监听器:

public class MyListener extends AnalysisEventListener<MyModel> {

  // 在读取完一行数据后调用
  @Override
  public void invoke(MyModel data, AnalysisContext context) {
    // do something
  }

  // 在读取完所有数据后调用
  @Override
  public void doAfterAllAnalysed(AnalysisContext context) {
    // do something
  }

}

在上面的代码中,MyListener类继承了AnalysisEventListener类,并重写了其中的两个方法。在读取Excel文件时,EasyExcel会在适当的时候调用这些方法,您可以在这些方法中处理事件。

例如,您可以在invoke()方法中处理读取完一行数据后的事件,并在doAfterAllAnalysed()方法中处理读取完所有数据后的事件。

5、以上方法的优缺点

实现ExcelListener接口:

优点:

  • 可以处理读取过程中的更多事件,包括读取开始和结束时的事件。
  • 可以更灵活地处理读取的每一行数据。

缺点:

  • 需要实现接口并重写多个方法,可能需要更多的代码。

使用回调函数:

优点:

  • 可以更灵活地处理读取的每一行数据。
  • 代码简洁,易于理解和维护。

缺点:

  • 不能处理读取过程中的更多事件,只能处理读取完一行数据后的事件。

继承AnalysisEventListener类:

优点:

  • 已经为每一行数据提供了默认的实现,只需要重写其中的方法即可。
  • 代码简洁,易于理解和维护。

缺点:

  • 不能处理读取过程中的更多事件,只能处理读取完一行数据和读取完所有数据后的事件。
  • 如果需要更灵活地处理读取的每一行数据,可能需要实现更多的代码。

总之,您可以根据自己的需要选择实现ExcelListener接口、使用回调函数或继承AnalysisEventListener类来处理读取Excel文件中的。文章来源地址https://www.toymoban.com/news/detail-489973.html

到了这里,关于EasyExcel轻松读取Excel文件!的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 后端:使用easyExcel实现解析Excel文件读取数据。前端:Excel模板下载、前端上传文件

            本篇是EasyExcel快速入门知识,讲解如何读取Excel文件,对Excel中错误信息如空字符、必填项为空、表格格式校验做到处理 ,并给出了实际项目中示例代码;为什么要使用easyexcel;原因是相比于poi,easyexcel更加轻量级,读取写入API方便,并且在工作中占用内存较小;

    2024年02月05日
    浏览(49)
  • Apache POI及easyExcel读取及写入excel文件

    目录 1.excel 2.使用场景 3.Apache POI 4.easyExcel 5.总结 1.excel excel分为两版,03版和07版。 03版的后缀为xls,最大有65536行。 07版的后缀为xlsx,最大行数没有限制。 2.使用场景 将用户信息导出到excel表格中。 将excel中的数据读取到数据库中。 3.Apache POI (1)说明 Apache POI是Apache软件基金会

    2024年02月06日
    浏览(35)
  • Springboot基于easyexcel实现一个excel文件包含多个sheet表格的数据导出

    EasyExcel 是一款基于Java的开源Excel操作工具,它提供了简单且强大的 API,使开发人员可以轻松地读写、操作和生成Excel文件。 EasyExcel 支持 Excel 文件的导入和导出,可以处理大量数据,具有高性能和低内存占用。它可以读取 Excel 文件中的数据,并将数据转换为 Java 对象,也可

    2024年02月03日
    浏览(39)
  • 基于EasyExcel的Excel读取

    1.引入依赖 2.读取器代码: 3.测试

    2024年02月12日
    浏览(30)
  • EasyExcel读取多sheet excel异常

    使用Spring Boot集成EasyExcel进行导入excel多sheet,执行异常 file是MultipartFile,入参,主要处理流程如下 异常: com.alibaba.excel.exception.ExcelCommonException: Convert excel format exception.You can try specifying the ‘excelType’ yourself 按照描述,缺少excelType参数,补充后,代码大概如下: 异常: com.

    2024年02月16日
    浏览(21)
  • python如何批量读取一个文件夹里的所以excel文件

    在数据分析工作中,尝尝需要处理多个不同月的excel文件,但无奈与excel文件的局限性,不能同时处理多个月的excel数据,所以python的批量读取excel文件就显得十分重要,下面我将展示如何用python将每个月度的excel数据进行读取并汇总处理和输出。 最好excel的文件名就是按照日期

    2024年02月16日
    浏览(33)
  • 使用java解析和读取excel表格(EasyExcel的简单使用)

    ** ** Apache POI、JXL、Alibaba EasyExcel等。其中Apache POI基于DOM方式进行解析,将文件直接加载内存,所以速度较快,适合Excel文件数据量不大的应用场景; EasyExcel是一个基于Java的、快速、简洁、解决大文件内存溢出的Excel处理工具。他能让你在不用考虑性能、内存的等因素的情况下

    2024年01月16日
    浏览(32)
  • EasyExcel导出Excel文件

    方法一 导入EasyExcel依赖 创建实体类 OrderServiceImpl 如果希望多个sheet导出那么可以 测试类 方法二 导入EasyExcel依赖 编写ExcelUtil 编写Service层代码 controller层代码 方法一与方法二都使用了EasyExcel进行Excel的导出,区别在于方法一建立了实体类进行Excel的导出,这样的好处是可以直

    2024年02月14日
    浏览(25)
  • 使用EasyExcel读写Excel文件

    笔者之前一直使用POI读写Excel文件,最近有个需求需要读取大概80万行数据的Excel,使用POI读取到10.2万行左右就卡死不动了,而且CPU占用直接拉满到100%,内存占用也很高。 查找资料后,发现POI提供了读取大量数据的方法,但是用起来比较复杂。同时看到有人提到用EasyExcel读取

    2024年02月13日
    浏览(34)
  • EasyExcel实现Excel文件导入导出功能

    Java领域解析、生成Excel比较有名的框架有Apache poi、jxl等。但他们都存在一个严重的问题就是非常的耗内存。如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc。 EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节省内存著称。

    2024年02月02日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包