Java将多种字符串格式解析为Date

项目在解析 Excel 的时候,日期数据可能有多种格式:"2020-10-1"、"2020.10.1"、"2020/10/1"、"2020年10月1日"四种格式,需要解析成 Java 中的 Date 类型。

方法一:

定义好对应的日期格式数组,如“yyyy-MM-dd”、“yyyy.MM.dd”、“yyyy/MM/dd”、“yyyy年MM月dd日”,循环遍历直到解析得到 Date 返回,所有的格式均解析失败则返回 null。

实现参考:java 将多种字符串格式 解析为Date格式

方法二:

换一种思路:我们可以使用正则匹配通过 String.replaceAll 方法把"2020-10-1"、"2020.10.1"、"2020/10/1"、"2020年10月1日"都转换成"2020-10-1",再按照“yyyy-MM-dd”的格式转换成 Date 类型就可以了。

大致代码实现如下:

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * @author dcc
 * @since 2021/3/25
 */
public class DateTest {
    private static ThreadLocal<SimpleDateFormat> SIMPLE_DATE_FORMAT = ThreadLocal.withInitial(() -> new SimpleDateFormat("yyyy-MM-dd"));

    private static final String regex = "\\/|\\.|年|月|日";

    public static void main(String[] args) {
        String s1 = "2018-10-01";
        System.out.println(parseDate(s1));
        String s2 = "2018.10.2";
        System.out.println(parseDate(s2));
        String s3 = "2018/10/3";
        System.out.println(parseDate(s3));
        String s4 = "2018年10月4日";
        System.out.println(parseDate(s4));
    }

    public static Date parseDate(String dateStr) {
        if (dateStr == null || dateStr.length() == 0) {
            return null;
        }
        Date date = null;
        try {
            date = SIMPLE_DATE_FORMAT.get().parse(dateStr.replaceAll(regex, "-"));
            return date;
        } catch (ParseException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return null;
    }
}

测试输出结果:

Mon Oct 01 00:00:00 CST 2018
Tue Oct 02 00:00:00 CST 2018
Wed Oct 03 00:00:00 CST 2018
Thu Oct 04 00:00:00 CST 2018

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值