EasyExcel导出转换@ExcelProperty注解中converter不生效,以及EasyExcel导入日期转换失败问题
用EasyExcel做导出,需要用@ExcelProperty做格式转换,比如日期转换,枚举类转换
然后新建一个转换类
里面有两个实现方法,converToJavaData是导入时,数据转换定义格式,converToExcelData是导出时做数据转换的。
然后回到问题,导出时没有进入这个注解转换类,首先debug看一下
这个注解转换类执行方法是AbstractExcelWriteExecutor.java里面的doConvert方法,看了下参数ExceContentProperty是空的,然后看了下WriteHolder里面的exceContentProperty参数对应的headClazz是空的,然后去看监听器ModelBuildEventListener。
也就是说,他的导出取值都是通过head里取得字段值。我们需要初始化要要导出得模板类初始化一下head属性就可以了。
后续,附带一个导入时日期转换异常,万能转换方法,放到converToJavaData里用
if(null==cellData) {
return null;
}
LocalDateTime result=null;
if(cellData.getType()==CellDataTypeEnum.NUMBER) {
if (contentProperty == null || contentProperty.getDateTimeFormatProperty() == null) {
Date date= DateUtil.getJavaDate(cellData.getNumberValue().doubleValue(),
globalConfiguration.getUse1904windowing(), null);
result =date.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
} else {
Date date= DateUtil.getJavaDate(cellData.getNumberValue().doubleValue(),
contentProperty.getDateTimeFormatProperty().getUse1904windowing(), null);
result =date.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
}
}if(cellData.getType()==CellDataTypeEnum.STRING) {
String value=cellData.getStringValue();
if(value.contains("-")) {
try {
result= LocalDateTime.parse(value,DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
/* result= LocalDateTime.parse(cellData.getStringValue());*/
} catch (Exception e) {
e.printStackTrace();
}
}
else if(value.contains("/")) {
try {
result= LocalDateTime.parse(new SimpleDateFormat("yyyy/MM/dd HH:mm:ss").format( value) );
} catch (Exception e) {
e.printStackTrace();
}
}
}
return result;
更多推荐
所有评论(0)