基于EasyExcel的读取exl并返回成功/失败数量及原因,并将导入失败exl的导出到系统路径中

本文介绍了如何使用EasyExcel库读取Excel文件,并记录导入过程中的成功与失败数量,同时将导入失败的数据导出到系统路径。内容包括配置监听器、业务逻辑处理、错误信息封装以及测试案例。
摘要由CSDN通过智能技术生成

首先,这个是读取和导出exl都需要用到的实体类的基类,这个是可以扩展的,读取失败的exl想要加入其它列的字段都可以加在这里
pom

 <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.1.4</version>
        </dependency>
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.metadata.BaseRowModel;

//读取exl的错误导出基础类,用来存放基础数据
public class EasyExcelErrBaseVo  extends BaseRowModel {

    @ExcelProperty(value = {"失败原因"})
    protected  String remark;

    public String getRemark() {
        return remark;
    }

    public void setRemark(String remark) {
        this.remark = remark;
    }
}

二 读取的入口

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelReader;
import com.alibaba.excel.read.metadata.ReadSheet;
import lombok.extern.slf4j.Slf4j;

/**
 * 这个是读取exl的工具类
 */
@Slf4j
public class EasyExcelReadUtil {


    public static JsonMessage easyRead(EasyRealInterface easyRealInterface, String fileName, Class cls,String errfilepath) {
        try {
            // 写法2:
            easyRealInterface.setErrcla(cls);
            ExcelReader excelReader = EasyExcel.read(fileName,cls, new EasyExcelLister(easyRealInterface)).build();
            ReadSheet readSheet = EasyExcel.readSheet(0).build();
            excelReader.read(readSheet);
            // 这里千万别忘记关闭,读的时候会创建临时文件,到时磁盘会崩的
            excelReader.finish();
           return easyRealInterface.finish(errfilepath);
        } catch (Exception e) {
            log.error(easyRealInterface.getreportName() + "读取excel异常", e);
            return new JsonMessage(false,"服务器异常,请重新上传");
        }
    }
}

三 配置监听器

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.excel.metadata.CellData;
import com.alibaba.fastjson.JSON;
import lombok.extern.slf4j.Slf4j;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * excel读取的监听器
 */
@Slf4j
public class EasyExcelLister<T> extends AnalysisEventListener<T> {
    /**
     * 每隔5条存储数据库,实际使用中可以3000条,然后清理list ,方便内存回收
     */
    private static  int BATCH_COUNT = 30;
    List<T> list = new ArrayList<T>();

    EasyRealInterface easyRealInterface;


    /**
     * 如果使用了spring,请使用这个构造方法。每次创建Listener的时候需要把spring管理的类传进来
     *
     * @param easyRealInterface ,传入批量处理的接口,每达到多少条就进行一次批量处理
     */
    public EasyExcelLister(EasyRealInterface easyRealInterface) {
       this.easyRealInterface=easyRealInterface;
    }

    /**
     *
     * @param easyRealInterface ,继承该接口进行业务逻辑的处理,每次保存多少
     * @param BATCH_COUNT ,每次解析的数量
     */
    public EasyExcelLister(EasyRealInterface easyRealInterface,int BATCH_COUNT) {
        this.easyRealInterface=easyRealInterface;
        this.BATCH_COUNT=BATCH_COUNT;
    }

    /**
     * 这个每一条数据解析都会来调用
     *
     * @param data
     *            one row value. Is is same as {@link AnalysisContext#readRowHolder()}
     * @
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值