我目前使用的是:
[0-1]{1}[0-9]{1}[0-3]{1}[0-9]{1}[0-1]{1}[0-9]{1}匹配6位数的日期。有没有办法使这更具限制性,我的问题是,我的文本中包含其他6-8位数字,并且我在非日期序列中偶尔会得到假阳性。
有什么建议吗?
谢谢!
附注:应说明年份将始终大于2000,小于当前日期,因此对年份进行了限制。
发布于 2012-07-06 03:24:21
为此,你应该使用一个实际的日期解析器,这不仅是为了简化对实际可能值的解析(例如,13个月是无效的),而且也是为了为闰年等做准备。
通常,您喜欢的语言中的日期解析器应该能够解析MMDDYY格式的字符串,并在失败时给出某种反馈。
发布于 2012-07-06 03:34:57
一次改进,只持续了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])从技术上讲,有一种方法可以计算出闰年,但这有点过头了。
发布于 2012-07-06 03:24:08
http://www.regular-expressions.info/dates.html BTW:您将无法仅使用正则表达式来处理闰年(尽管理论上可能,但这是不切实际的)。您应该使用适当的日期解析器。
https://stackoverflow.com/questions/11351019
复制相似问题