当前位置: 首页 > news >正文

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大模型解释注解的意思,这样就能找到你想要的答案了。

http://www.dtcms.com/a/69792.html

相关文章:

  • HCIA-AI人工智能笔记2:大模型演进趋势
  • Dify Docker 私有化部署遇到的问题
  • 合React宝宝体质的自定义节流hook
  • Compose 实践与探索十 —— 其他预先处理的 Modifier
  • vscode python相对路径的问题
  • 基于 Verilog 的数字电路设计与仿真:乘数器与多路复用器实践
  • LVGL第三方库的使用(中文库)
  • windows协议不再续签,华为再无windows可用,将于四月发布鸿蒙PC
  • Vue3 开发的 VSCode 插件
  • 996引擎 - 红点系统
  • 前端面试题---vue项目打包时, 内存不足了怎么办 为什么会出现这样的情况
  • SpringBoot事件驱动
  • 翻硬币问题
  • 【Docker compose】neo4j容器安装apoc插件
  • 医疗送药机器人“空间拓扑优化+动态算法决策+多级容错控制”三重链式编程技术解析与应用
  • 【WiFi 7核心技术及未来挑战】
  • 搭建刷题专业版小程序系统
  • 【机器学习chp13--(上)】人工神经网络(MLP结构 + KAN结构 + 卷积神经网络)
  • AI Agent 时代开幕-Manus AI与OpenAI Agent SDK掀起新风暴
  • 4.2 Reactive 对象的深度类型约束方案
  • 婚恋之红娘相亲小程序开发功能与设计详解
  • 福特售后再添亮点,为烈马模块化车身改装提供专业支持
  • Qt运行xxx.so can not open shared object file
  • MacOS 上使用终端彻底格式化 U 盘
  • 介绍HTTP协议基本结构与Linux中基本实现HTTPServer
  • 如何取消GitHub Copilot订阅付费?
  • 非零初始条件系统的传递函数分析
  • Kafka的零拷贝
  • 推荐系统基础
  • 【2025】基于python+django的驾校招生培训管理系统(源码、万字文档、图文修改、调试答疑)