EasyExcel的入门教程

本文介绍了如何使用阿里巴巴的EasyExcel库进行Excel数据的读取和写入操作。首先,引入EasyExcel的依赖,然后创建一个实体类DemoData,包含字段注解以指定Excel表头。接着,展示了三种不同的数据导出方式,并提供了数据生成的示例。最后,演示了两种读取Excel数据的方法,包括数据监听器的使用,方便对读取的数据进行处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.导入依赖

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

 2.准备一个实体类


@Data
public class DemoData {
    @ExcelProperty("字符串标题") // 导出时的excel表格表头
    private String string;
    @ExcelProperty("日期标题")
    private Date date;
    @ExcelProperty("数字标题")
    private Double doubleData;
    /**
     * 忽略这个字段
     */
    @ExcelIgnore
    private String ignore;
}

3.进行简单的导出

 private List<DemoData> data() {
        List<DemoData> 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;
    }
/**
  *  导出简单的excel
  */
@Test
public void uploadExcel() {
     // 写法1:
     String fileName = path + "EasyExcel.xlsx";
     // 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为sheet 然后文件流会自动关闭
     // 如果这里想使用03 则 传入excelType参数即可
     EasyExcel.write(fileName, DemoData.class).sheet("sheet").doWrite(data());
     
     // 写法2:
     EasyExcel.write(fileName, DemoData.class)
                .sheet("模板")
                .doWrite(() -> {
                    // 分页查询数据
                    return data();
                });
     // 写法3:可以根据模板导出,这里不做介绍
     
}

4.简单读取

 @Test
    public void simpleRead() {
        // 写法1:JDK8+ ,不用额外写一个DemoDataListener
       
        String fileName = path + "EasyExcel.xlsx";
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        // 这里每次会读取100条数据 然后返回过来 直接调用使用数据就行
        EasyExcel.read(fileName, DemoData.class, new PageReadListener<DemoData>(dataList -> {
            for (DemoData demoData : dataList) {
                System.out.println(JSON.toJSONString(demoData));
            }
        })).sheet().doRead();

        
        // 写法2:
         // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).sheet().doRead();    
        
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值