沉梦听雨的编程指南 沉梦听雨的编程指南
首页
  • 基础篇
  • 集合篇
  • 并发篇
  • JVM
  • 新特性
  • 计算机网络
  • 操作系统
  • 数据结构与算法
  • 基础篇
  • MySql
  • Redis
  • 达梦数据库
  • Spring
  • SpringBoot
  • Mybatis
  • Shiro
  • 设计须知
  • UML画图
  • 权限校验
  • 设计模式
  • API网关
  • RPC
  • 消息队列
  • SpringCloud
  • 分布式事务
  • 云存储
  • 搜索引擎
  • 多媒体框架
  • 虚拟机
  • 开发工具篇
  • 工具库篇
  • 开发技巧篇
  • 工具类系列
  • 随笔
  • 前端环境搭建
  • HTML与CSS
  • JS学习
  • Vue3入门
  • Vue3进阶
  • 黑马Vue3
  • 脚手架搭建
  • 瑞吉外卖
  • 黑马点评
  • vue-blog
  • 沉梦接口开放平台
  • 用户中心
  • 聚合搜索平台
  • 仿12306项目
  • 壁纸小程序项目
  • RuoYi-Vue
  • 博客搭建
  • 网站收藏箱
  • 断墨寻径摘录
  • 费曼学习法
Github (opens new window)

沉梦听雨

时间是最好的浸渍剂,而沉淀是最好的提纯器🚀
首页
  • 基础篇
  • 集合篇
  • 并发篇
  • JVM
  • 新特性
  • 计算机网络
  • 操作系统
  • 数据结构与算法
  • 基础篇
  • MySql
  • Redis
  • 达梦数据库
  • Spring
  • SpringBoot
  • Mybatis
  • Shiro
  • 设计须知
  • UML画图
  • 权限校验
  • 设计模式
  • API网关
  • RPC
  • 消息队列
  • SpringCloud
  • 分布式事务
  • 云存储
  • 搜索引擎
  • 多媒体框架
  • 虚拟机
  • 开发工具篇
  • 工具库篇
  • 开发技巧篇
  • 工具类系列
  • 随笔
  • 前端环境搭建
  • HTML与CSS
  • JS学习
  • Vue3入门
  • Vue3进阶
  • 黑马Vue3
  • 脚手架搭建
  • 瑞吉外卖
  • 黑马点评
  • vue-blog
  • 沉梦接口开放平台
  • 用户中心
  • 聚合搜索平台
  • 仿12306项目
  • 壁纸小程序项目
  • RuoYi-Vue
  • 博客搭建
  • 网站收藏箱
  • 断墨寻径摘录
  • 费曼学习法
Github (opens new window)
  • 开发工具篇

  • 工具库篇

    • lombok工具库

    • EasyExcel小记

      • 工具类
      • 文件导入
      • 文件导出
      • 自定义日期格式化注解
        • 1、注解
        • 2、转换类
    • 定时任务相关

    • Hutool工具库

    • 极光推送学习
    • OkHttp学习
    • BigDecimal类详解
    • PdfBox学习
    • OCR功能实现
  • 开发技巧篇

  • 工具类系列

  • 随笔

  • 开发日常
  • 工具库篇
  • EasyExcel小记
沉梦听雨
2024-11-05
目录

自定义日期格式化注解

# 自定义日期格式化注解

# 1、注解

/**
 * 日期字段格式化
 *
 * @author chenmeng
 */
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
public @interface ExcelDateTimeFormat {

    /**
     * @return 日期格式
     */
    String pattern();

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

知识点说明:

  1. 元注解

    • 元注解是用于注解其他注解的注解。
    • 常见的元注解包括 @Retention、@Target、@Documented 和 @Inherited。
  2. @Target

    • 用途:指定注解可以应用的目标元素类型。
    • 参数:{ElementType.FIELD} 表示该注解只能应用于字段(属性)。
    • 作用:确保注解不会被误用在其他地方,如方法、类等。
  3. @Retention

    • 用途:指定注解的保留策略,即注解在什么阶段会被保留。
    • 参数:RetentionPolicy.RUNTIME 表示注解会在运行时保留,可以通过反射访问。
    • 作用:允许在运行时通过反射获取注解的信息,通常用于框架或库中动态处理注解。
  4. @Inherited

    • 用途:指定注解是否可以被子类继承。
    • 作用:只有当注解类型应用于类时,@Inherited 才有效。对于方法、字段等其他元素无效。
    • 注意:在这个例子中,注解是应用于字段的,所以 @Inherited 实际上不会生效。@Inherited 主要用于类级别的注解。

# 2、转换类

/**
 * 日期字段格式转换类
 *
 * @author chenmeng
 */
public class DateTimeConverter implements Converter<String> {

    public static final String PATTERN_DATE_IMPORT = "yyyy-MM-dd";
    public static final String PATTERN_DATE_EXPORT = "yyyy年MM月dd日";

    public static final String PATTERN_DATETIME_IMPORT = "yyyy-MM-dd HH:mm:ss";
    public static final String PATTERN_DATETIME_EXPORT = "yyyy年MM月dd日 HH时mm分ss秒";

    @Override
    public Class<?> supportJavaTypeKey() {
        throw new UnsupportedOperationException("暂不支持,也不需要");
    }

    @Override
    public CellDataTypeEnum supportExcelTypeKey() {
        throw new UnsupportedOperationException("暂不支持,也不需要");
    }

    /**
     * 导入
     */
    @Override
    public String convertToJavaData(ReadCellData readCellData, ExcelContentProperty contentProperty,
                                    GlobalConfiguration globalConfiguration) {
        String value = readCellData.getStringValue();
        if (StrUtil.isBlank(value)) {
            return null;
        }
        // 转换成日期类型
        DateTime dateTime = DateUtil.parse(value);
        // 获取需要格式
        String pattern = getPattern(contentProperty);
        return DateUtil.format(dateTime, pattern);
    }

    /**
     * 导出
     */
    @Override
    public WriteCellData<String> convertToExcelData(String dateStr, ExcelContentProperty contentProperty,
                                                    GlobalConfiguration globalConfiguration) {
        if (dateStr == null) {
            return null;
        }
        // 转换成日期类型
        DateTime dateTime = DateUtil.parse(dateStr);
        // 获取需要格式
        String pattern = getPattern(contentProperty);
        return new WriteCellData<>(DateUtil.format(dateTime, pattern));
    }

    private static String getPattern(ExcelContentProperty contentProperty) {
        return contentProperty.getField().getAnnotation(ExcelDateTimeFormat.class).pattern();
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
上次更新: 2024/11/5 23:38:48
文件导出
基础入门

← 文件导出 基础入门→

Theme by Vdoing | Copyright © 2023-2025 沉梦听雨 | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式