EasyExcel 读取数据为null

常见问题:

原因一:实体对象中使用注解@Accessors

@Accessors(chain = true),全属性为空,与chain为true/false无关(-1是自个写的未匹配(也就是null)返回-1)

原因二:实体类字段不符合驼峰命名规范:

        如手首个字母为小写的情况

原因三:@ExcelProperty中index或者value值错误

        

我遇到的坑:

      我导入多个sheet表时,有其中一个获取不到数据,其他sheet表的数据均可正常获取。网上找了许久未找到问题。后来发现获取不到数据的sheet表名中有空格:

EasyExcel.read(is, noModleDataListener).extraRead(CellExtraTypeEnum.MERGE).ignoreEmptyRow(false).sheet(sheetName).headRowNumber(headRowNumber).doRead();
用上述方法读取数据,但是未进入invoke方法;

猜测sheet表名中包含空格等特殊符号时,使用sheetName不能找到sheet表,所以并未调用invoke方法;

解决:

传入sheet表编号后,可以正常获取数据。

源码ExcelReaderBuilder类中:

    public ExcelReaderSheetBuilder sheet(Integer sheetNo) {
        return this.sheet(sheetNo, (String)null);
    }

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值