springboot easyexcel导入/导出excel自定义时间格式
创始人
2024-11-12 08:10:55
0

        当使用java的easyExcel进行excel导入和导出时,如何接收表格中的各种自定义时间格式字符串转成LocalDateTime及导出时如何将LocalDateTime转为各种时间格式字符串。

一、新建自定义时间格式转换

        

package com.logwing.wyadmin.framework.excel;  import com.alibaba.excel.converters.Converter; import com.alibaba.excel.enums.CellDataTypeEnum; import com.alibaba.excel.metadata.GlobalConfiguration; import com.alibaba.excel.metadata.data.ReadCellData; import com.alibaba.excel.metadata.data.WriteCellData; import com.alibaba.excel.metadata.property.ExcelContentProperty; import org.apache.poi.ss.usermodel.DateUtil;  import java.time.LocalDateTime; import java.time.ZoneId; import java.time.format.DateTimeFormatter; import java.time.format.DateTimeFormatterBuilder; import java.time.temporal.ChronoField; import java.util.Date;  public class LocalDateTimeConverter implements Converter {      @Override     public Class supportJavaTypeKey() {         return LocalDateTime.class;     }      @Override     public CellDataTypeEnum supportExcelTypeKey() {         return CellDataTypeEnum.STRING;     }      @Override     public LocalDateTime convertToJavaData(ReadCellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) {         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("-")) {                 DateTimeFormatter formatter = new DateTimeFormatterBuilder()                         .appendPattern("yyyy-MM-dd[[' 'HH][:mm][:ss]")                         .parseDefaulting(ChronoField.HOUR_OF_DAY, 0)                         .parseDefaulting(ChronoField.MINUTE_OF_HOUR, 0)                         .parseDefaulting(ChronoField.SECOND_OF_MINUTE, 0)                         .parseDefaulting(ChronoField.MILLI_OF_SECOND, 0)                         .toFormatter();                  result = LocalDateTime.parse(value, formatter);             }             else if(value.contains("/")) {                 DateTimeFormatter formatter = new DateTimeFormatterBuilder()                         .appendPattern("yyyy/MM/dd[[' 'HH][:mm][:ss]")                         .parseDefaulting(ChronoField.HOUR_OF_DAY, 0)                         .parseDefaulting(ChronoField.MINUTE_OF_HOUR, 0)                         .parseDefaulting(ChronoField.SECOND_OF_MINUTE, 0)                         .parseDefaulting(ChronoField.MILLI_OF_SECOND, 0)                         .toFormatter();                  result = LocalDateTime.parse(value, formatter);             }         }         return result;     }      @Override     public WriteCellData convertToExcelData(LocalDateTime value, ExcelContentProperty contentProperty,                                                GlobalConfiguration globalConfiguration) {         var dateTimeFormatProperty = contentProperty.getDateTimeFormatProperty();         var formatter = "yyyy-MM-dd HH:mm:ss";         if (dateTimeFormatProperty != null) {             formatter = dateTimeFormatProperty.getFormat();         }          return new WriteCellData<>(value.format(DateTimeFormatter.ofPattern(formatter)));     }  } 

二、实体类中使用

在为easyExcel定义的实体类中心添加自定义注解,例如
@ExcelProperty(value = "维运开航日期", converter = LocalDateTimeConverter.class) @DateTimeFormat("yyyy/MM/dd") // 指定导出格式 private LocalDateTime sailingDateFormatter; 

在converter中引入自定义的接收和转换规则

@DateTimeFormat的作用是定义导出的格式,在contentProperty方法中的contentProperty.getDateTimeFormatProperty()的getFormat方法可以取到这边定义的格式,从而在写excel时转为对应格式(注意判断contentProperty.getDateTimeFormatProperty()是否为null,没定义DateTimeFormat时就会为null,判空避免空指针)

相关内容

热门资讯

妙计辅助!创思维激k有挂吗(辅... 妙计辅助!创思维激k有挂吗(辅助挂)切实存在有辅助脚本(果真有挂)创思维激k有挂吗辅助器是一种具有地...
记者获悉!aapoker破解侠... 记者获悉!aapoker破解侠是真的吗,来玩app破解版,练习教程(有挂讲解)1、很好的工具软件,可...
学习辅助!新道游辅助软件下载(... 学习辅助!新道游辅助软件下载(辅助挂)竟然真的有辅助方法(有挂透视)1、打开软件启动之后找到中间准星...
黑科技代打!wepoker模拟... 黑科技代打!wepoker模拟器哪个,wepoker可以免费玩吗,绝活教程(有挂细节)wepoker...
办法辅助!wepoker修改工... 办法辅助!wepoker修改工具(辅助挂)都是真的有辅助工具(有挂教程)1、在wepoker修改工具...
明白辅助挂!佛手在线有挂吗,w... 明白辅助挂!佛手在线有挂吗,wepoker透视功能下载,积累教程(有挂猫腻)1、完成wepoker透...
要领辅助!老友辅助工具下载(辅... 要领辅助!老友辅助工具下载(辅助挂)果然真的有辅助技巧(真实有挂)1、完成老友辅助工具下载辅助器v3...
此事迅速冲上热搜!sohoo ... 此事迅速冲上热搜!sohoo poker辅助,来玩app破解版,指南书教程(有挂攻略)1、金币登录送...
举措辅助!牛总管辅助神器(辅助... 举措辅助!牛总管辅助神器(辅助挂)确实确实有辅助软件(有挂透明挂)进入游戏-大厅左侧-新手福利-激活...
值得注意的是!wepoker透... 值得注意的是!wepoker透视脚本免费,sohoo开挂辅助,诀窍教程(有挂教程)wepoker透视...