常见问题:
原因一:实体对象中使用注解@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);
}