正则表达式 验证日期(全).doc_第1页
正则表达式 验证日期(全).doc_第2页
正则表达式 验证日期(全).doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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日,故每四年增加一日,这一年有366日,就是闰年。但四年增加一日比四个回归年又多0.0312日,400年后将多3.12日,故在400年中少设3个闰年,也就是在400年中只设97个闰年,这样公历年的平均长度与回归年就相近似了。由此规定:年份是整百数的必须是400的倍数才是闰年,例如 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 用正则表达式验证日期的难点有二:一是大小月份的天数不同,二是闰年的考虑。 对于第一个难点,我们首先不考虑闰年,假设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的正则表达式: (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整除即可,相应的正则表达式为: (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 YYYY/MM/DD YYYY_MM_DD YYYY.MM.DD 的形式 match: 2008-2-29 2008/02/29 not 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)$)4.例子iDate=2011-02-28Function RegExpfind(p,s) Dim regEx Set regEx=new RegExp regEx.Pattern=p regEx.IgnoreCase=True regEx.Global=True regExpfind=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)|(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论