EasyExcel入门(最简单的读)

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

官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel (alibaba.com)

因为暂时项目没有用到,所以不急,知道了这个技术。就想着学着用一下!

最简单的读

 先看官方文档给的用法和解释!!!

导入依赖

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.3.2</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.70</version>
        </dependency>

创建实体类

 自己准备一个Excel表格。

@Data
public class DemoData {
    private String name;

    private String sex;

    private String age;
}

测试

官方提供了4种写法

写法一:

final String fileName = "C:\\Users\\gong'chao\\Desktop\\58_com_resumes_bj.xls";
    /**
     * 最简单的读 - 01
     */
    @Test
    void readExcel01(){
        AtomicInteger i = new AtomicInteger();
        EasyExcel.read(fileName, DemoData.class, new PageReadListener<DemoData>(dataList -> {
            for (DemoData demoData : dataList) {
                System.out.println("读取到一条数据" + JSON.toJSONString(demoData));
                i.getAndIncrement();
            }
            // 输出集合长度
            System.err.println(dataList.size());
        })).sheet().doRead();
        // 输出总行数
        System.out.println(i);
    }

EasyExcel入门(最简单的读),java,excelEasyExcel入门(最简单的读),java,excel

点击PageReadListener查看源码:

EasyExcel入门(最简单的读),java,excel

 默认是一行一行读取。然后可以再点进ListUtils中查看,可以知道,一行一行的将数据存进集合中,当长度到100时重新new一个集合,则原来的集合对象不被引用交给垃圾回收。这就是 Easy Excel 处理大文件内存溢出的一种方式吧。

---   个人理解

然后可以看出实体类映射的三个字段输出的值不匹配。按照官网给出的注解:

@Data
public class DemoData {
    @ExcelProperty(value = "姓名")
    private String name;

    @ExcelProperty(value = "性别")
    private String sex;

    @ExcelProperty(index = 5)
    private String age;
}

可以指定列名,也可以指定下标。这样就正确映射了

写法二:内部类

    /**
     * 最简单的读 - 02
     */
    @Test
    void readExcel02(){
        EasyExcel.read(fileName, DemoData.class, new ReadListener<DemoData>(){
            // 单次缓存的数量
            public static int BATCH_COUNT = 200;
            // 临时存储
            private List<DemoData> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);

            @Override
            public void invoke(DemoData data, AnalysisContext context) {
                cachedDataList.add(data);
                if(cachedDataList.size() >= BATCH_COUNT) {
                    System.err.println(cachedDataList.size());
                    System.err.println("已保存至数据库\n已完成清理 list");
                    cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
                }
            }

            @Override
            public void doAfterAllAnalysed(AnalysisContext context) {
                System.err.println("已将剩余数据保存至数据库");
            }
        }).sheet().doRead();
    }

写法三:外部类

定义一个类

public class read03 implements ReadListener<DemoData> {
    // 单次缓存的数量
    public static int BATCH_COUNT = 200;
    // 临时存储
    private List<DemoData> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);

    public void invoke(DemoData data, AnalysisContext context) {
        cachedDataList.add(data);
        if(cachedDataList.size() >= BATCH_COUNT) {
            System.err.println(cachedDataList.size());
            System.err.println("已保存至数据库\n已完成清理 list");
            cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
        }
    }

    public void doAfterAllAnalysed(AnalysisContext context) {
        System.err.println("已将剩余数据保存至数据库");
    }
}
    /**
     * 最简单的读 - 03
     */
    @Test
    void readExcel03(){
        EasyExcel.read(fileName, DemoData.class, new read03()).sheet().doRead();
    }

写法四:

   /**
     * 最简单的读 - 04
     */
    @Test
    void readExcel04(){
        try (ExcelReader excelReader = EasyExcel.read(fileName, DemoData.class, new read03()).build()) {
            // 构建一个sheet 这里可以指定名字或者no
            ReadSheet readSheet1 = EasyExcel.readSheet(0).sheetName("员工表").build();
            ReadSheet readSheet2 = EasyExcel.readSheet(1).sheetName("请假表").build();
            System.out.println(readSheet1.toString());
            System.out.println(readSheet2.toString());
            // 读取一个sheet
            excelReader.read(readSheet1);
            excelReader.read(readSheet2);
        }
    }

写法四中可以通过下标指定工作表和相应的名称。 

总结

之后真正要用EasyExcel技术时再研究其他用法,之后再更新!文章来源地址https://www.toymoban.com/news/detail-705922.html

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

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

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

相关文章

  • java处理Excel表格(EasyExcel)

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

    2024年02月15日
    浏览(35)
  • Java 使用 easyexcel 读取 excel 文件

    easyexcel 官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel 1. 引入依赖并给出示例 excel     2. 两种读取的方式         (1)确定表头:建立对象,和表头形成映射。(这里以此为例)         (2)不确定表头:每一行映射为 MapString, Object。 3. 先创建 excel 中表头对应

    2024年02月12日
    浏览(41)
  • Java EasyExcel高效读取保存excel文件

    阿里开源出一款易上手,且比较节省内存的Excel操作框架:EasyExcel。EasyExcel是一行一行进行读取,再大的excel也不会出现OOM。 Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存

    2024年02月16日
    浏览(37)
  • java解析excel,poi和easyExcel

    做项目遇到上传excel并解析excel内容组装成结构话json,网上查了很多方法,做了poi和easyExcel两个方法的对比 两者都可以解析excel文件,但是两个也有不同: 一、poi 官方说明:https://poi.apache.org/components/index.html A、03版excel和07版excel: 1)03版excel最多65536行,最大列数是256列,

    2023年04月22日
    浏览(34)
  • SpringBoot中java操作excel【EasyExcel】

    EasyExcel 处理Excel;简单记录,方便日后查询! 官方文档: Easy Excel (alibaba.com) Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版

    2024年02月15日
    浏览(32)
  • Java 导出Excel表格生成下拉框-EasyExcel

     

    2024年02月11日
    浏览(41)
  • 【JAVA】easyexcel 导出excel文件带多个图片

    最终效果  pom版本 实现代码  

    2024年02月16日
    浏览(26)
  • Java——使用EasyExcel导出动态列的Excel

    多多点赞,会变好看! 多多留言,会变有钱! 有些时候列表的列可能是动态的,需要根据动态表头导出Excel文件,这时候可以使用下面的方法解决: 静态列导出代码:

    2024年02月15日
    浏览(38)
  • java实现excel的导出之使用easyExcel

    在我们的项目需求中,经常会遇到导出的需求,其中excel的导出最为常见。生成Excel比较有名的框架有Apache poi,jxl等,但他们都存在一个严重的问题就是非常的耗内存,如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc. EasyExcel是阿里巴巴

    2024年02月15日
    浏览(33)
  • JAVA解析EXCEL(JExcelAPI,POI,EasyExcel)

    demo代码:https://github.com/RwTo/excel-demo JAVA解析Excel 一般有三种方式 JExcelAPI POI EasyExcel 官网:https://jexcelapi.sourceforge.net/ 仅支持 2003 版本的Excel 也就是 后缀名为 xls 的文件 采用流式处理模型,逐行读取和写入 ——因此 可以处理大量数据,一般不会出现OOM Demo 读xls 文件 写xls 文件

    2024年02月15日
    浏览(30)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包