正则表达式 验证日期(全)

上传人:wt****50 文档编号:37983752 上传时间:2018-04-25 格式:DOC 页数:3 大小:16.50KB
返回 下载 相关 举报
正则表达式 验证日期(全)_第1页
第1页 / 共3页
正则表达式 验证日期(全)_第2页
第2页 / 共3页
正则表达式 验证日期(全)_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《正则表达式 验证日期(全)》由会员分享,可在线阅读,更多相关《正则表达式 验证日期(全)(3页珍藏版)》请在金锄头文库上搜索。

1、1.验证日期的正则表达式加入闰年的判断以及思路分析进入正题之前,我们需要澄清两个概念:什么是合法的日期范围?对于不同的应用场景,这个问题有不同的解释。这里采纳MSDN 中的约定:DataTime值类型标示值范围在公元(基督纪元)0001年1月1日午夜12:00:00到公元(C.E.) 9999年12月31日晚上11:59:59之间的日期和时间。关于闰年的阐释。人民教育出版社小学数学室的解释浅明易懂:关于公历闰年是这样规定的:地球绕太阳公转一周叫做一回归年,一回归年长365日5时48 分46秒。因此,公历规定有平年和闰年,平年一年有365日,比回归年短0.2422日,四年共 短0.9688日,故

2、每四年增加一日,这一年有366日,就是闰年。但四年增加一日比四个回归 年又多0.0312日,400年后将多3.12日,故在400年中少设3个闰年,也就是在400年中只设97 个闰年,这样公历年的平均长度与回归年就相近似了。由此规定:年份是整百数的必须是40 0的倍数才是闰年,例如 1900年,2010 年就不是闰年。清楚了以上两个概念,进入正题。首先要验证年份,显然,年份范围为 0001-9999,匹配YYYY的正则表达式为:0-931-9|0-921-90-91|0-911-90-92|1-90-93其中 0-9 也可以表示为 d,但 d 不如 0-9 直观,因此下面将一直采用0-9用正则表

3、达式验证日期的难点有二:一是大小月份的天数不同,二是闰年的考虑。对于第一个难点,我们首先不考虑闰年,假设2月份都是28天,这样,月份和日期可以分成 三种情况:月份为1,3,5,7,8,10,12,天数范围为01-31,匹配MM-DD的正则表达式为:(013578|102)-(01-9|120-9|301)月份为4,6,9,11,天数范围为01-30,匹配MM-DD的正则表达式为:(0469|11)-(01-9|120-9|30)月份为2,考虑平年情况,匹配MM-DD的正则表达式为:02-(01-9|10-9|20-8)根据上面的成果,我们可以得到匹配平年日期格式为YYYY-MM-DD的正则表达

4、式:(0-931-9|0-921-90-91|0-911-90-92|1-90-93)-(013578|102)- (01-9|120-9|301)|(0469|11)-(01-9|120-9|30)|(02-(01-9|10-9|20-8)接下来我们来解决第二个难点:闰年的考虑。根据闰年的定义,我们可以将闰年分为两类 :能被4整除但不能被100整除的年份。寻找后两位的变化规律,可以很快得到下面的正则 匹配:(0-92)(048|2468048|1357926)能被400整除的年份。能被400整除的数肯定能被100整除,因此后两位肯定是00,我们只 要保证前两位能被4整除即可,相应的正则表达式

5、为:(048|2468048|1357926)002.将平年和闰年的日期验证表达式合并,我们得到做宏验证日期格式为YYYY-MM- DD的正则表达式为:(0-931-9|0-921-90-91|0-911-90-92|1-90-93)-(013578|102)- (01-9|120-9|301)|(0469|11)-(01-9|120-9|30)|(02-(01-9|10-9|20-8)|(0- 92)(048|2468048|1357926)|(048|2468048|1357926)00)-02-29)3.最强验证日期的正则表达式,添加了闰年的验证这个日期正则表达式支持YYYY-MM-DD

6、YYYY/MM/DDYYYY_MM_DDYYYY.MM.DD的形式match: 2008-2-29 2008/02/29not match: 2008-2-30 2007/02/29完整的正则表达式如下:(0-931-9|0-921-90-91|0-911-90-92|1-90-93)- /._(013578|102)-/._(01-9|120-9|301)|(0469|11)-/._(01-9|120-9|30)|(02- (01-9|10-9|20-8)|(0- 92)(048|2468048|1357926)|(048|2468048|1357926)00)-/._02-/._29)$)

7、4.例子iDate=2011-02-28Function RegExpfind(p,s)Dim regExSet regEx=new RegExpregEx.Pattern=pregEx.IgnoreCase=TrueregEx.Global=TrueregExpfind=regEx.Test(s) End FunctionIf (RegExpfind(“(0-931-9|0-921-90-91|0-911-90-92|1-90- 93)-(013578|102)-(01-9|120-9|301)|(0469|11)-(01-9|120- 9|30)|(02-(01-9|10-9|20-8)|(0- 92)(048|2468048|1357926)|(048|2468048|1357926)00)-02- 29)$“,iDate) Thenmsgbox “日期格式正确“elsemsgbox “日期格式不正确“ End If

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号