EasyExcel操作Excel表格

一、EasyExcel介绍

1.1 介绍

EasyExcel 是一个基于 Java 的简单易用的 Excel 文件读写工具,它提供了一种简单而又高效的方式来读取、写入和操作 Excel 文件。EasyExcel 是阿里巴巴开源的项目,它旨在简化开发人员处理 Excel 文件的流程,使得操作 Excel 文件变得更加容易和高效。具体介绍和说明可以看官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel

1.2 EasyExcel 特点

① 简单易用:EasyExcel 提供了简洁明了的 API,使得开发人员可以轻松地进行 Excel 文件的读写操作,不需要过多的代码即可完成复杂的 Excel 文件处理任务。

② 高性能:EasyExcel 在设计上充分考虑了性能优化,底层采用了流式读写的方式,能够高效处理大型 Excel 文件,提高处理速度。

③ 支持多种数据格式:EasyExcel 支持读取和写入多种数据格式,包括基本数据类型、集合、对象等,同时支持复杂的表格结构和样式设置。

④ 丰富的功能:EasyExcel 提供了丰富的功能,包括对单元格样式、图表、公式等的支持,可以满足各种复杂的 Excel 文件处理需求。

⑤ 灵活可扩展:EasyExcel 的设计灵活可扩展,可以通过自定义监听器来实现特定的业务逻辑,同时支持插件机制,方便开发人员根据需求进行功能扩展和定制化开发。

二、Java使用EasyExcel

2.1 添加pom依赖


    com.alibaba
    easyexcel
    3.3.3


 

    com.alibaba.fastjson2
    fastjson2
    2.0.29




    org.projectlombok
    lombok

2.2 读Excel 数据
  • 读取的表格数据

EasyExcel操作Excel表格_第1张图片

  • 读取代码示例
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

import java.util.Date;
/**
 * 基础数据类
 **/
@Getter
@Setter
@EqualsAndHashCode
public class DemoData {
    @ExcelProperty("字符串标题")
    private String string;
    @ExcelProperty("日期标题")
    private Date date;
    @ExcelProperty("数字标题")
    private Double doubleData;

    /**
     * 忽略这个字段
     */
    @ExcelIgnore
    private String ignore;
}



import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.read.listener.PageReadListener;
import com.alibaba.excel.read.listener.ReadListener;
import com.alibaba.excel.util.ListUtils;
import com.alibaba.fastjson2.JSON;
import com.zhuimengren.easyexcel.entity.DemoData;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import java.util.List;



@Slf4j
public class ReadTest {
    /**
     * 写法1:JDK8+ ,不用额外写一个DemoDataListener
     * since: 3.0.0-beta1
     */
    @Test
    public void simpleRead1() {
        String fileName = "src/main/resources/demo/demo.xlsx";
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        // 这里默认每次会读取100条数据 然后返回过来 直接调用使用数据就行
        // 具体需要返回多少行可以在`PageReadListener`的构造函数设置
        EasyExcel.read(fileName, DemoData.class, new PageReadListener(dataList -> {
            for (DemoData demoData : dataList) {
                log.info("读取到一条数据{}", JSON.toJSONString(demoData));
            }
        })).sheet().doRead();
    }

    /**
     * 写法2:
     * 匿名内部类 不用额外写一个DemoDataListener
     */
    @Test
    public void simpleRead2() {
        String fileName = "src/main/resources/demo/demo.xlsx";
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        EasyExcel.read(fileName, DemoData.class, new ReadListener() {
            /**
             * 单次缓存的数据量
             */
            public static final int BATCH_COUNT = 100;
            /**
             *临时存储
             */
            private List cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);

            @Override
            public void invoke(DemoData data, AnalysisContext context) {
                cachedDataList.add(data);
                if (cachedDataList.size() >= BATCH_COUNT) {
                    saveData();
                    // 存储完成清理 list
                    cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);
                }
            }

            @Override
            public void doAfterAllAnalysed(AnalysisContext context) {
                saveData();
            }

            /**
             * 加上存储数据库
             */
            private void saveData() {
                for (DemoData demoData : cachedDataList) {
                    log.info("读取到一条数据{}", JSON.toJSONString(demoData));
                }
            }
        }).sheet().doRead();
    }


}

  • 执行结果

EasyExcel操作Excel表格_第2张图片

2.3 写Excel数据
  • 写入数据的Excel模版

EasyExcel操作Excel表格_第3张图片

  • 写入代码示例
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

import java.util.Date;
/**
 * 基础数据类
 **/
@Getter
@Setter
@EqualsAndHashCode
public class DemoData {
    @ExcelProperty("字符串标题")
    private String string;
    @ExcelProperty("日期标题")
    private Date date;
    @ExcelProperty("数字标题")
    private Double doubleData;

    /**
     * 忽略这个字段
     */
    @ExcelIgnore
    private String ignore;
}


import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.util.ListUtils;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.zhuimengren.easyexcel.entity.DemoData;
import org.junit.jupiter.api.Test;

import java.util.Date;
import java.util.List;


public class WriteTest {

    /**
     * 写法1 JDK8+
     * since: 3.0.0-beta1
     */
    @Test
    public void simpleWrite1() {
        // 注意 simpleWrite在数据量不大的情况下可以使用(5000以内,具体也要看实际情况),数据量大参照 重复多次写入
        String fileName = "src/main/resources/demo/write-demo.xlsx";
        // 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭
        // 如果这里想使用03 则 传入excelType参数即可
        EasyExcel.write(fileName, DemoData.class)
            .sheet("模板")
            .doWrite(() -> {
                // 分页查询数据
                return data();
            });
    }

    /**
     * 写法2
     */
    @Test
    public void simpleWrite2() {
        String fileName = "src/main/resources/demo/write-demo.xlsx";
        // 这里 需要指定写用哪个class去写
        try (ExcelWriter excelWriter = EasyExcel.write(fileName, DemoData.class).build()) {
            WriteSheet writeSheet = EasyExcel.writerSheet("模板").build();
            excelWriter.write(data(), writeSheet);
        }
    }

    private List data() {
        List list = ListUtils.newArrayList();
        for (int i = 0; i < 10; i++) {
            DemoData data = new DemoData();
            data.setString("字符串" + i);
            data.setDate(new Date());
            data.setDoubleData(0.56);
            list.add(data);
        }
        return list;
    }

}

说明:

上述代码示例是最基础的读和写的demo,复杂操作请看官网示例代码。关于Easyexcel | Easy Excel

你可能感兴趣的:(java)