easyexcel简单使用方法

1.pom导入依赖

2.最简单的读

定义读的对象

@Data
@EqualsAndHashCode
public class UserInfo {

    /**
     * id
     */
    @ExcelProperty("编号")
    private String code;

    /**
     * 用户昵称
     */
    @ExcelProperty("姓名")
    private String name;
}

编写监听器

@Slf4j
public class DemoDataListener implements ReadListener<UserInfo> {
 @Override
    public void invoke(UserInfo userInfo, AnalysisContext analysisContext) {
       System.out.println(userInfo);
    }

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

测试

 public static void main(String[] args) {
        String fileName = "E:\\code\\src\\main\\resources\\table.xlsx";
        // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
        EasyExcel.read(fileName, UserInfo.class, new DataListener()).sheet().doRead();
    }

3.同步读

public static void main(String[] args) {
  String fileName = "xxx"
  List<UserInfo> userList = EasyExcel.read(fileName).head(UserInfo.class).sheet().doReadSync();
        for (UserInfo userInfo : userList) {
            System.out.println(userInfo);
        }
}

4.总结

两种读取对象的方式:
确定表头:建立对象和表头映射关系

不确定表头:每一行的数据映射为Map<String, Object>
两种读取模式:
监听器(Listener):先创建监听器在读取文件时绑定监听器。单独抽离处理逻辑。条一条的读。

同步读:无需创建监听器,一下需要读取完成数据到内存中。方便简洁但可能内存溢出。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值