我目前正在使用:
[0-1]{1}[0-9]{1}[0-3]{1}[0-9]{1}[0-1]{1}[0-9]{1}
匹配6位数的日期。有没有办法使这个更具限制性,我的问题是我在文本中包含其他6-8位数字,我偶尔会在非日期序列中出现误报。
有什么建议吗?
谢谢!
p.s应该说年份将始终高于2000年且低于当前日期,因此限制当年。
答案 0 :(得分:4)
你应该使用一个实际的日期解析器,不仅可以简化解析实际可能的值(即第13个月无效),而且还可以为闰年等做好准备。
通常,您喜欢的语言中的日期解析器应该能够解析MMDDYY格式的字符串,并在失败时提供某种反馈。
答案 1 :(得分:2)
一项改进,仅为12个月,31天,2000年至2012年。
(?:0[1-9]|1[0-2])(?:0[1-9]|[1-2][0-9]|3[0-1])(?:200[0-9]|201[1-2])
我知道其中一些破折号不是必需的;添加它们以便于阅读。
然后你可以进一步,根据月份进行28,30或31天。
(?:(?:0[13578]|1[02])31|(?:0[13-9]|1[0-2])(?:29|30)|(?:0[1-9]|1[0-2])(?:0[1-9]|1[0-9]|2[0-8]))(?:200[0-9]|201[1-2])
技术上有一种方法可以计算出闰年,但这有点过分了。
答案 2 :(得分:1)
http://www.regular-expressions.info/dates.html 顺便说一句:你只能用一个正则表达式来处理闰年(虽然理论上它可能是不切实际的)。您应该使用正确的日期解析器。
答案 3 :(得分:0)
使用此正则表达式[0-1]\d[0-3]\d[2-9]\d{3}
但不可能与当前日期相互作用