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

  • 相关阅读:
    javascript生成ics、日程、日历
    Linux下基于GTK人脸识别界面设计
    CentOS7中安装VMwareTools(非图形界面)
    Mysql优化笔记
    Mistral AI:探索LLM推理的吞吐、时延及成本空间
    CleanMyMac X版本4.14.2中文版新功能介绍
    天猫精灵、Blinker 控制esp32自带灯熄灭---Micropython版本
    了解一下事务的概念
    PyTorch图文安装教程(Win10),含遇到的问题及解决办法
    网络安全(黑客)自学笔记
  • 原文地址:https://blog.csdn.net/zhangtongpeng/article/details/133070621