正则表达式校验日期时间格式

刺骨的言语ヽ痛彻心扉 2022-12-28 15:30 262阅读 0赞

目录

日期部分校验

概念

校验yyyyMMdd

校验yyyy-MM-dd

时间部分校验

校验HHmmss

校验HH-mm-ss

校验日期+时间部分

校验yyyyMMddHHmmss

校验 yyyy-MM-dd HH:mm:ss

应用举例


日期部分校验

概念

首先,我们先了解2个概念:

1、合法的日期范围:

  • DateTime 值类型表示值范围在公元(基督纪元)0001 年 1 月 1 日午夜 12:00:00 到公元 (C.E.) 9999 年 12 月 31 日晚上 11:59:59 之间的日期和时间。*

2、平年和闰年

地球绕太阳公转一周叫做一回归年,一回归年长365日5时48分 46秒。因此,公历规定有平年和闰年,平年一年有365日,比回归年短0.2422日,四年共短0.9688日,故每四年增加一日,这一年有366日,就 是闰年。但四年增加一日比四个回归年又多0.0312日,400年后将多3.12日,故在400年中少设3个闰年,也就是在400年中只设97个闰年,这样公历年的平均长度与回归年就相近似了。由此规定:年份是整百数的必须是400的倍数才是闰年,例如1900年、2100年就不是闰年。

验证YYYY年份:

  1. \d{3}[1-9]|\d{2}[1-9]\d|\d[1-9]\d{2}|[1-9]\d{3}

验证MMDD月日:

大月(1、3、5、7、8、10、12月,有31天)

  1. (0[13578]|1[02])(0[1-9]|[12]\d|3[01])

小月(4、6、9、11月,有30天)

  1. (0[469]|11)(0[1-9]|[12]\d|30)

平年2月(有28天)

  1. 02(0[1-9]|[1]\d|2[0-8])

闰年:

能被4整除但不能被100整除的年份

  1. (\d{2})(0[48]|[2468][048]|[13579][26])

能被400整除的年份

  1. ((0[48]|[2468][048]|[3579][26])00)

闰年2月(有29天)

  1. ((\d{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))0229

校验yyyyMMdd

最终,验证YYYYMMDD的正则表达式为

  1. ((\d{3}[1-9]|\d{2}[1-9]\d|\d[1-9]\d{2}|[1-9]\d{3})(((0[13578]|1[02])(0[1-9]|[12]\d|3[01]))|((0[469]|11)(0[1-9]|[12]\d|30))|(02(0[1-9]|[1]\d|2[0-8]))))|(((\d{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))0229)

校验yyyy-MM-dd

精确到日即可,即年月日,格式:yyyy-MM-dd,例如:2016-12-13

  1. ((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29))

时间部分校验

校验HHmmss

校验时分秒:格式:HHmmss

  1. ([0-1]?[0-9]|2[0-3])([0-5][0-9])([0-5][0-9])

校验HH-mm-ss

校验时分秒:格式:HH-mm-ss

  1. ([0-1]?[0-9]|2[0-3])-([0-5][0-9])-([0-5][0-9])

校验日期+时间部分

校验yyyyMMddHHmmss

  1. ((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})(((0[13578]|1[02])(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)(0[1-9]|[12][0-9]|30))|(02(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))0229))([0-1]?[0-9]|2[0-3])([0-5][0-9])([0-5][0-9])

校验 yyyy-MM-dd HH:mm:ss

校验 yyyy-MM-dd HH:mm:ss(日期和时间之间有一个或多个空格)

  1. ((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29))\\s+([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])

应用举例

卫生数据元校验

  1. case "D8":
  2. if(!value_str.matches("((\\d{3}[1-9]|\\d{2}[1-9]\\d|\\d[1-9]\\d{2}|[1-9]\\d{3})(((0[13578]|1[02])(0[1-9]|[12]\\d|3[01]))|((0[469]|11)(0[1-9]|[12]\\d|30))|(02(0[1-9]|[1]\\d|2[0-8]))))|(((\\d{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))0229)")){
  3. valid = false;
  4. tipInfo = "不符合日期格式yyyyMMdd";
  5. break;
  6. }
  7. break;
  8. case "T6":
  9. if(!value_str.matches("([0-1]?[0-9]|2[0-3])([0-5][0-9])([0-5][0-9])")){
  10. valid = false;
  11. tipInfo = "不符合时间格式HHmmss";
  12. break;
  13. }
  14. break;
  15. case "DT15":
  16. if(!value_str.matches("(((\\d{3}[1-9]|\\d{2}[1-9]\\d|\\d[1-9]\\d{2}|[1-9]\\d{3})(((0[13578]|1[02])(0[1-9]|[12]\\d|3[01]))|((0[469]|11)(0[1-9]|[12]\\d|30))|(02(0[1-9]|[1]\\d|2[0-8]))))|(((\\d{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))0229))(T)(([0-1]?[0-9]|2[0-3])([0-5][0-9])([0-5][0-9]))")){
  17. valid = false;
  18. tipInfo = "不符合日期时间格式yyyyMMddTHHmmss";
  19. break;
  20. }
  21. break;

参考文章:

https://www.cnblogs.com/Alisa68/p/13208704.html

https://www.cnblogs.com/yyy-blog/p/10593983.html

发表评论

表情:
评论列表 (有 0 条评论,262人围观)

还没有评论,来说两句吧...

相关阅读