EasyExcel入门(最简单的读)

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

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

最简单的读

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

导入依赖

XML 复制代码
        <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表格。

java 复制代码
@Data
public class DemoData {
    private String name;

    private String sex;

    private String age;
}

测试

官方提供了4种写法

写法一:

java 复制代码
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);
    }

点击PageReadListener查看源码:

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

--- 个人理解

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

java 复制代码
@Data
public class DemoData {
    @ExcelProperty(value = "姓名")
    private String name;

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

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

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

写法二:内部类

java 复制代码
    /**
     * 最简单的读 - 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();
    }

写法三:外部类

定义一个类

java 复制代码
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("已将剩余数据保存至数据库");
    }
}
java 复制代码
    /**
     * 最简单的读 - 03
     */
    @Test
    void readExcel03(){
        EasyExcel.read(fileName, DemoData.class, new read03()).sheet().doRead();
    }

写法四:

java 复制代码
   /**
     * 最简单的读 - 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技术时再研究其他用法,之后再更新!

相关推荐
Ray Liang1 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Java水解1 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SimonKing5 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean5 小时前
Jackson View Extension Spring Boot Starter
java·后端
Seven976 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
皮皮林55116 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河16 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程19 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅21 小时前
Java面向对象入门(类与对象,新手秒懂)
java