easyExcel日期字符串格式统一处理

1.遇到日期导入转换Date失败情况

excel里面日期是字符串,java实体类和数据库都是日期类型

导入转换

public class EasyExcelString2DateConvert implements Converter<Date> {

   // 指定转化参数的Java类型
    @Override
    public Class<?> supportJavaTypeKey() {
        return String.class;
    }

   // 指定转化参数对应的单元格类型
    @Override
    public CellDataTypeEnum supportExcelTypeKey() {
        return CellDataTypeEnum.STRING;
    }

   // 单元格参数类型转化为Java类型处理逻辑
    @Override
    public Date convertToJavaData(ReadCellData<?> cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
        //多种模式 待添加
        if(StringUtil.isDate0(cellData.getStringValue())){
            return  DateUtils.parseDate(cellData.getStringValue(),"yyyyMMdd");
        }
         if(StringUtil.isDateTime(cellData.getStringValue())){
            return  DateUtils.parseDate(cellData.getStringValue(),"yyyyMMdd HH:mm:ss");
        }

        return  DateUtils.parseDate(cellData.getStringValue(),"yyyy/MM/dd");

    }
}

2.在实体类里面注解ExcelProperty加入

   @TableField("交易时间")
@ExcelProperty(value = "交易时间",converter = EasyExcelString2DateConvert.class)
   @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
   @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
   private Date 交易时间;

然后导入

EasyExcel.read(file.getInputStream(), Abc.class, new EasyExcelListener<Abc>(abcService) ).sheet().doReadSync();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值