用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;

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐