EasyExcel导入到spring项目中

本文介绍了如何使用EasyExcel库处理Excel文件,包括确定表头和不确定表头的读取对象方式,以及监听器模式和同步读模式的读取模式。重点讲解了各自的特点、适用场景及具体操作步骤。
摘要由CSDN通过智能技术生成

可以直接用EasyExcel来导入表格

读取模式

当使用 EasyExcel 处理 Excel 文件时,我们通常面临两种读取对象的方式:确定表头和不确定表头。此外,EasyExcel 提供了两种读取模式:监听器和同步读。

读取对象的方式

1. 确定表头
  • 方式: 建立对象,与 Excel 表头形成映射关系。
  • 优势: 类型安全,通过对象的属性与表头字段建立直观的映射。
  • 使用场景: 适用于已知 Excel 表头且具有确定结构的情况。
2. 不确定表头
  • 方式: 每一行数据映射为 Map<String, Object>
  • 优势: 适用于表头不确定或动态变化的情况,对于不同结构的 Excel 文件也能够处理。
  • 使用场景: Excel 表头可能发生变化,或者需要一套通用的处理逻辑。

读取模式

1. 监听器模式
  • 特点:

    • 先创建监听器,在读取文件时将监听器绑定。
    • 单独抽离处理逻辑,代码清晰易于维护。
    • 逐行处理,适用于大规模数据的场景。
  • 使用场景: 处理大量数据,逻辑处理比较复杂的情况。

2. 同步读模式
  • 特点:

    • 无需创建监听器,一次性获取完整数据。
    • 方便简单,但在数据量大时可能会有等待时长,甚至可能引发内存溢出。
  • 使用场景: 数据量较小或者对于一次性获取所有数据有要求的情况。

补充说明

  • EasyExcel 提供了对不同读取对象方式和读取模式的支持,可以根据实际需求选择合适的方式。
  • 在确定表头时,使用对象方式更为直观和类型安全。在不确定表头时,使用 Map 方式更为灵活。
  • 监听器模式适用于大规模数据的处理,能够在读取过程中逐行处理,减少内存占用。
  • 同步读模式适用于数据量相对较小,且一次性获取全部数据的场景,代码较为简单。

具体步骤

导入pom

<!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->  
<dependency>  
    <groupId>com.alibaba</groupId>  
    <artifactId>easyexcel</artifactId>  
    <version>3.2.1</version>  
</dependency>

新建excel对象

package com.castle.usercenter.easyExcel;

import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;

/**
 * 用户信息
 */
@Data
public class TableUserExcel {
    /**
     * id
     */
    @ExcelProperty("编号")
    private String id;
    /**
     * 用户昵称
     */
    @ExcelProperty("昵称")
    private String username;
}

建立监听器

监听器可以一行行的解析数据

package com.castle.usercenter.easyExcel;

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.read.listener.ReadListener;
import lombok.extern.slf4j.Slf4j;

// 有个很重要的点 DemoDataListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
@Slf4j
public class DataListener implements ReadListener<TableUserExcel> {


    /**
     * 这个每一条数据解析都会来调用
     *
     * @param data
     * @param context
     */
    @Override
    public void invoke(TableUserExcel data, AnalysisContext context) {
        System.out.println("导入成功");
    }

    /**
     * 所有数据解析完成了 都会来调用
     *
     * @param context
     */
    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        log.info("所有数据解析完成!");
    }
}

读取数据

package com.castle.usercenter.easyExcel;

import com.alibaba.excel.EasyExcel;

import java.util.List;

/**
 * 读取Excel
 */
public class ImportExcel {
    public static void main(String[] args) {
        // 写法1:JDK8+ ,不用额外写一个DemoDataListener
        // since: 3.0.0-beta1
        String fileName = "E:\\project\\partner\\partner-backend\\user-center-backend-master\\src\\main\\resources\\userInfo.xls";
        synchronousRead(fileName);
    }

    /**
     * 监听器读取
     */
    public static void readByListener(String fileName) {
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        // 这里每次会读取100条数据 然后返回过来 直接调用使用数据就行
        EasyExcel.read(fileName, TableUserExcel.class, new DataListener()).sheet().doRead();
    }
    /**
     * 同步读
     */
    public static void synchronousRead(String fileName) {
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 同步读取会自动finish
        List<TableUserExcel> list = EasyExcel.read(fileName).head(TableUserExcel.class).sheet().doReadSync();
        for (TableUserExcel e : list) {
            System.out.println(e);
        }
    }
}

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值