任意时间字符串转换成时间,无需指定解析模板

6 篇文章 0 订阅
2 篇文章 0 订阅

此方法适用于做excel导入,以及时间格式不可控的情况

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

/**
 * @Classname: DateUtils
 * @Description: TODO
 * @Author: Neo
 * @Date: 2018/11/9 9:48
 * @Version: 1.0
 */
public class DateUtils {

    /**
     * @Description: 任意时间字符串转换成时间,无需指定解析模板
     * @param:  日期
     * @return: 
     * @Author: Neo
     * @Date: 2018/11/9 9:50
     * @Version: 1.0
     */
    public static Date parseStringToDate(String date) throws ParseException {
        String parse = date.replaceFirst("[0-9]{4}([^0-9]?)", "yyyy$1");
        parse = parse.replaceFirst("^[0-9]{2}([^0-9]?)", "yy$1");
        parse = parse.replaceFirst("([^0-9]?)[0-9]{1,2}([^0-9]?)", "$1MM$2");
        parse = parse.replaceFirst("([^0-9]?)[0-9]{1,2}( ?)", "$1dd$2");
        parse = parse.replaceFirst("( )[0-9]{1,2}([^0-9]?)", "$1HH$2");
        parse = parse.replaceFirst("([^0-9]?)[0-9]{1,2}([^0-9]?)", "$1mm$2");
        parse = parse.replaceFirst("([^0-9]?)[0-9]{1,2}([^0-9]?)", "$1ss$2");
        DateFormat format = new SimpleDateFormat(parse);
        return format.parse(date);
    }


    public static void main(String[] args) {
        try {
            Date d1 = parseStringToDate("2018年11月1日");
            Date d2 = parseStringToDate("2018-11-2");
            Date d3 = parseStringToDate("2018/11/3");
            Date d4 = parseStringToDate("2018.11.4");
            Date d5 = parseStringToDate("2018115");
            Date d6 = parseStringToDate("2018年11月1日 11:11:11");
            Date d7 = parseStringToDate("2018115 12:12:12");
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            System.out.println("d1:"+sdf.format(d1));
            System.out.println("d2:"+sdf.format(d2));
            System.out.println("d3:"+sdf.format(d3));
            System.out.println("d4:"+sdf.format(d4));
            System.out.println("d5:"+sdf.format(d5));
            System.out.println("d6:"+sdf.format(d6));
            System.out.println("d7:"+sdf.format(d7));
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

测试结果如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值