JAVA判断时间格式为 "YYYY-MM-DD"
2017-12-20 00:13
911 查看
工作中遇到一个问题,要在JAVA代码中检查所传入的字符串形式的时间格式是否正确。
本宝宝在网上搜了一圈,发现常用的方法如下:
上面这段代码可以对日期的有效性进行检查,对不合法的字符串日期还会进行自动的计算使其合法。比如“2007-13-02”就会被自动计算为Wed Jan 02 00:00:00 CST 2008。加上formatter.setLenient(false);可以让程序严格校验,不合法的日期格式不自动转换。
然而,我输入”2017-1-2”,也是正确的格式
这不是我要的。
我要的是—四位数的年份两位数的日期和月份中间用中横线分隔—这样的格式。
新手小白,一筹莫展。大佬一语点醒,可以单独检查这样的格式,然后再去检查字符串日期的有效性啊~
用正则检查格式,然后再用上面的代码检查有效性。合起来的代码在下面:
以上是一次问题的解决,代码片段来自网络,在此做个记录。
本宝宝在网上搜了一圈,发现常用的方法如下:
import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Date; public class DataTest { public static void main (String [] args){ String str = "2007-01-02"; DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd"); try{ Date date = formatter.parse(str); System.out.print("格式正确!"); }catch(Exception e){ System.out.println("格式错误!"); } } }
上面这段代码可以对日期的有效性进行检查,对不合法的字符串日期还会进行自动的计算使其合法。比如“2007-13-02”就会被自动计算为Wed Jan 02 00:00:00 CST 2008。加上formatter.setLenient(false);可以让程序严格校验,不合法的日期格式不自动转换。
然而,我输入”2017-1-2”,也是正确的格式
这不是我要的。
我要的是—四位数的年份两位数的日期和月份中间用中横线分隔—这样的格式。
新手小白,一筹莫展。大佬一语点醒,可以单独检查这样的格式,然后再去检查字符串日期的有效性啊~
用正则检查格式,然后再用上面的代码检查有效性。合起来的代码在下面:
import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Date; import java.util.regex.Matcher; import java.util.regex.Pattern; public class DataTest { public static void main (String [] args){ String str = "2007-10-02"; String regex = "[0-9]{4}-[0-9]{2}-[0-9]{2}"; Pattern pattern = Pattern.compile(regex); Matcher m = pattern.matcher(str); boolean dateFlag = m.matches(); if (!dateFlag) { System.out.println("格式错误"); return ; } DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd"); formatter.setLenient(false); try{ Date date = formatter.parse(str); System.out.println(date); System.out.print("格式正确!"); }catch(Exception e){ System.out.println("格式错误!"); } } }
以上是一次问题的解决,代码片段来自网络,在此做个记录。
相关文章推荐
- java判断时间格式 //格式必须为“YYYY-MM-dd”
- java判断时间格式 //格式必须为“YYYY-MM-dd”
- java用正则,将形如"Tue JAN 10 00:00:00 CST 2009“格式的时间转化成年月日yyyy-MM-dd日期格式
- java利用正则表达式判断输入的日期格式为yyyy/MM/dd
- js扩展Date将时间格式化为"yyyy-MM-dd hh:mm:ss"格式的字符串
- 如何用sql语言只获得数据库当前日期,且格式为"yyyy-mm-dd"?
- 向mysql中插入格式为"yyyy-MM-dd HH:mm:ss"的时间
- 通过js将时间戳转换成"yyyy--mm--dd"格式
- rdlc报表的日期格式"yyyy/mm/dd 00/00/00"转换为"yyyy-mm-dd"
- Java获取格式为yyyy-MM-dd的Date时间
- JAVA中判断是否是正确的日期格式(yyyy-mm-dd)
- C++判断时间格式满足yyyy-mm-dd-hh:mm与时间1小于时间2
- "Mon Dec 28 00:00:00 CST 2008"的格式字符串转换 yyyy-MM-dd
- <fmt:formatDate value="${ abc}" pattern="hh:mma, MM/dd/yyyy" /> jstl 时间data格式
- 时间戳转换为"yyyy-MM-dd hh:mm:ss"格式(24小时)
- 将MYSQL中以INT(11)存储的时间以"YYYY-MM-DD"格式来显示
- JAVA 判断是否是正确的日期格式(yyyy-mm-dd)
- 将字符串"yyyy-MM-dd'T'hh:mm:ss"转换其他时间格式
- java将 Date原始格式EEE MMM dd HH:mm:ss Z yyyy"转成指定格式
- 【Java】将 "yyyy-MM-dd'T'HH:mm:ss.SSSZ" 转化为 "yyyy-MM-dd HH:mm:ss"