收藏 分享(赏)

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

上传人:hyngb9260 文档编号:7829630 上传时间:2019-05-27 格式:DOC 页数:3 大小:16.50KB
下载 相关 举报
正则表达式 验证日期(全).doc_第1页
第1页 / 共3页
正则表达式 验证日期(全).doc_第2页
第2页 / 共3页
正则表达式 验证日期(全).doc_第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.96

2、88日,故每四年增加一日,这一年有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用

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

4、-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整除即可,相应

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

6、-DDYYYY/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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报