EasyExcel简介

生来就可爱ヽ(ⅴ<●) 提交于 2020-12-01 10:23:00

一 Excel导入导出的应用场景

1 数据导入

减轻录入工作量

2 数据导出

统计信息归档

3 数据传输

异构系统之间数据传输

二 EasyExcel简介

1 官方网站

https://github.com/alibaba/easyexcel

快速开始:https://www.yuque.com/easyexcel/doc/easyexcel

2 EasyExcel特点

Java领域解析、生成Excel比较有名的框架有Apache poi、jxl等。但他们都存在一个严重的问题就是非常的耗内存。如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc。

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

EasyExcel采用一行一行的解析模式,并将一行的解析结果以观察者的模式通知处理(AnalysisEventListener)

三 写实战

1 创建一个普通的maven项目

项目名:alibaba_easyexcel

2 pom中引入xml相关依赖

<dependencies>
    <!-- easyexcel -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>easyexcel</artifactId>
        <version>2.1.7</version>
    </dependency>
    <!-- easyexcel依赖slf4j-simple -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-simple</artifactId>
        <version>1.7.5</version>
    </dependency>
    <!-- easyexcel依赖xmlbeans -->
    <dependency>
        <groupId>org.apache.xmlbeans</groupId>
        <artifactId>xmlbeans</artifactId>
        <version>3.1.0</version>
    </dependency>
    <!-- lombok -->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.10</version>
    </dependency>
    <!-- junit -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
</dependencies>

3 创建实体类

@Data
public class ExcelStudentData {
    /**
     * 姓名
     */
    @ExcelProperty(value = "姓名", index = 2)
    private String name;
    /**
     * 生日
     */
    @DateTimeFormat("yyyy年MM月dd日HH时mm分ss秒")
    @ExcelProperty(value = "生日", index = 3)
    private Date birthday;
    /**
     * 薪资
     */
    @NumberFormat("#.##%")
    @ExcelProperty(value = "薪资", index = 5)
    private Double salary;
    /**
     * 忽略密码字段
     */
    @ExcelIgnore
    private String password;
}

4 创建测试

public class ExcelWriteTest {
    /**
     * 功能描述:07版测试
     *
     * @author cakin
     * @date 2020/11/30
     */
    @Test
    public void simpleWrite07() {
        String fileName = "F:/temp/simpleWrite-07.xlsx";
        EasyExcel.write(fileName, ExcelStudentData.class)
                .sheet("学生信息")
                .doWrite(data());
    }


    /**
     * 功能描述:03版测试
     *
     * @author cakin
     * @date 2020/11/30
     */
    @Test
    public void simpleWrite03() {
        String fileName = "F:/temp/simpleWrite-03.xls";
        EasyExcel.write(fileName, ExcelStudentData.class)
                .excelType(ExcelTypeEnum.XLS) // 默认是 XLSX
                .sheet("学生信息")
                .doWrite(data());
    }


    /**
     * 功能描述:构造数据
     *
     * @author cakin
     * @date 2020/11/30
     */
    private List<ExcelStudentData> data() {
        List<ExcelStudentData> list = new ArrayList<>();
        for (int i = 0; i < 65535; i++) {
            ExcelStudentData data = new ExcelStudentData();
            data.setName("Helen" + i);
            data.setBirthday(new Date());
            data.setSalary(0.12345);
            data.setPassword("123456");
            list.add(data);
        }
        return list;
    }
}

四 测试

五 说明 

  • 07版本的Excel和03版本的写入方式有所不同,03版本是一次性写入,可能会导致内容溢出问题,07版本是一条条写入。07版本写入文件后,大小较03版要小。
  • 03版本的Excel一次最多可写65536行,07版本没限制。
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!