easypoi导入Excel兼容日期和字符串格式的日期和时间

问题场景

在使用easypoi导入Excel时,涉及到的常用日期会有yyyy-MM-dd HH:mm:ss、yyyy-MM-dd和HH:mm:ss,但是Excel上面的格式可不止这些,用户总会输入一些其他格式,如

如果在定义verify时用下面这种格式定义,那么总会只能获取到一部分值,如定义成String则获取不到Date格式的值,定义成Date则获取不到String格式的值。

复制代码
public class verify implements IExcelModel, IExcelDataModel, Serializable {

@Excel(name = "xx日期")

private String dateExcel;

@Excel(name = "xx日期")

private Date dateExcel;

@Excel(name = "xx日期")

private Object dateExcel;

}

解决方法

easypoi版本

复制代码
<dependency>
    <groupId>cn.afterturn</groupId>
    <artifactId>easypoi-web</artifactId>
    <version>4.3.0</version>
</dependency>

定义verify使用Excel注解importFormat = "yyyy-MM-dd",注意要使用String去接收

@Excel(name = "xx日期",importFormat = "yyyy-MM-dd")

private String dateExcel;

当接收到了Excel原始值后会easypoi会格式化成importFormat格式,但是有些格式需要自己处理,只是通过该注解能够获取到了值,至于格式不一致,我们可以自己去转换,如下:

复制代码
public static String formatDateTime(String inputDate, DateTimeFormatter outputFormatter) {
    for (String format : SUPPORTED_FORMATS_DATE) {
        try {
            DateTimeFormatter inputFormatter = DateTimeFormatter.ofPattern(format);
            LocalDateTime dateTime = LocalDateTime.parse(inputDate, inputFormatter);
            return dateTime.format(outputFormatter); // 转换为标准格式
        } catch (DateTimeParseException e) {
            // 如果当前格式解析失败,继续尝试下一个格式
        }
    }
    return null; // 如果所有格式都无法解析,返回 null
}

private static final List<String> SUPPORTED_FORMATS_DATE = Arrays.asList(

"yyyy/M/d HH:mm:ss", // 2025/2/17 13:36:00

"yyyy-MM-dd HH:mm:ss", // 2025-02-17 13:36:00

"yyyy-M-dd HH:mm:ss", // 2025-2-17 13:36:00

"yyyy-MM-d HH:mm:ss", // 2025-2-17 13:6:00

"yyyy年MM月dd日 HH:mm:ss" // 2025年02月17日 13:36:00

);

通过该注解方式获取到值后在verifyHandler类处理成自己想要的格式。

总结

遇事不决问AI大模型,大模型乱答看源码解读各个注解的用途,通过AI大模型解释注解的意思,这样就能找到你想要的答案了。

相关推荐
杜子腾dd6 小时前
17.Excel:实用的 VBA 自动化程序
数据分析·自动化·excel
是孑然呀13 小时前
【小记】excel vlookup一对多匹配
excel
chaodaibing14 小时前
pandas读取pymysql和解析excel的一系列问题(版本不匹配)
excel·pandas
沉到海底去吧Go1 天前
【身份证识别表格】批量识别身份证扫描件或照片保存为Excel表格,怎么大批量将身份证图片转为excel表格?基于WPF和腾讯OCR的识别方案
ocr·wpf·excel·身份证识别表格·批量扫描件身份证转表格·图片识别表格·图片识别excel表格
a GISer doctor1 天前
EXCEL中嵌入其他表格等文件
excel
yngsqq1 天前
CAD属性图框值与Excel联动(CAD块属性导出Excel、excel更新CAD块属性)——CAD c#二次开发
excel
帆张芳显1 天前
前端EXCEL插件,智表ZCELL产品V3.0 版本发布,底层采用canvas全部重构,功能大幅扩展,性能极致提升,满足千万级单元格加载
前端·重构·excel·jquery·插件·智表
課代表1 天前
Excel VBA 词频统计宏
ui·excel··vba·模块·字典
LAM LAB2 天前
【WPS】怎么解决“word的复制表格”粘贴到“excel的单元格”变多行单元格的问题
word·excel·wps
Eiceblue2 天前
如何通过C# 获取Excel单元格的数据类型
开发语言·visualstudio·c#·excel