EasyExcel

两种读取对象的方式

1.确定表头:建立对应的对象实体类 进行映射

2.不确定的表头:每一行数据映射为Map<String,Object>

两种读取模式

1.监听器:先创建监听器对象 在读取文件时绑定监听器 单独抽取处理逻辑 代码清晰维护 一条条处理 适用于大数据量的场景

@Slf4j
public class TableListener implements ReadListener<TableUserInfo> {
    /**
     * 这个每一条数据解析都会来调用
     *
     * @param data    one row value. Is is same as {@link AnalysisContext#readRowHolder()}
     * @param context
     */
    @Override
    public void invoke(TableUserInfo data, AnalysisContext context) {
        System.out.println(data);
    }

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


}

2.同步器:无需创建监听器 要获取完整数据  一次性读取所有数据

public class ImportExcel {

    public static void main(String[] args) {
        String fileName = "D:\\桌面\\用户中心项目\\code\\user-center\\src\\main\\resources\\table_user_info.xlsx";
        readByListener(fileName);
        synchronousRead(fileName);
    }

    //监听器模式
    private static void readByListener(String fileName){
        // 写法1:JDK8+ ,不用额外写一个DemoDataListener
        // since: 3.0.0-beta1

        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        // 这里每次会读取3000条数据 然后返回过来 直接调用使用数据就行
        EasyExcel.read(fileName, TableUserInfo.class,new TableListener()).sheet().doRead();
    }

    //同步器模式
    private static void synchronousRead(String fileName){
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 同步读取会自动finish
        List<TableUserInfo> totalDataList = EasyExcel.read(fileName).head(TableUserInfo.class).sheet().doReadSync();
        for (TableUserInfo tableUserInfo : totalDataList) {
            System.out.println(tableUserInfo);
        }
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值