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;

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用EasyExcel的@ExcelProperty注解来实现自定义转换器。@ExcelProperty注解用于将Java对象的属性与Excel表格的列进行映射。 首先,您需要创建一个实现了Converter接口的自定义转换器类。Converter接口有两个方法需要实现:convertToExcelData和convertToJavaData。convertToExcelData方法将Java对象属性转换Excel表格要写入的数据,而convertToJavaData方法将Excel表格读取的数据转换Java对象属性。 以下是一个示例的自定义转换器类: ```java import com.alibaba.excel.converters.Converter; import com.alibaba.excel.metadata.CellData; import com.alibaba.excel.metadata.GlobalConfiguration; import com.alibaba.excel.metadata.property.ExcelContentProperty; public class CustomConverter implements Converter<Object> { @Override public Class<?> supportJavaTypeKey() { return null; // 返回支持的Java类型 } @Override public CellData<Object> convertToExcelData(Object value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception { // 将Java对象属性转换Excel表格要写入的数据,返回CellData对象 // 实现转换逻辑 return new CellData<>(value); } @Override public Object convertToJavaData(CellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception { // 将Excel表格读取的数据转换Java对象属性,返回对应类型的值 // 实现转换逻辑 return cellData.getData(); } } ``` 然后,在您的Java对象的属性上使用@ExcelProperty注解,并指定自定义转换器类: ```java public class YourObject { @ExcelProperty(converter = CustomConverter.class) private Object yourProperty; // 其他属性和方法 } ``` 这样,在使用EasyExcel库读取或写入Excel表格时,会自动应用您定义的转换器来实现自定义的转换逻辑。 希望对您有帮助!如有问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值