《常用正则表达式大全!.docx》由会员分享,可在线阅读,更多相关《常用正则表达式大全!.docx(8页珍藏版)》请在三一办公上搜索。
1、常用正则表达式大全!常用正则表达式大全!匹配中文字符的正则表达式: u4e00-u9fa5 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包括汉字在内):x00-xff 评注:可以用来计算字符串的长度 匹配空白行的正则表达式:ns*r 评注:可以用来删除空白行 匹配HTML标记的正则表达式:<(S*?)>*>.*?|<.*? /> 评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力 匹配首尾空白字符的正则表达式:s*|s*$ 评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式 匹
2、配Email地址的正则表达式:w+(-+.w+)*w+(-.w+)*.w+(-.w+)* 评注:表单验证时很实用 匹配网址URL的正则表达式:a-zA-z+:/s* 评注:网上流传的版本功能很有限,上面这个基本可以满足需求 匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):a-zA-Za-zA-Z0-9_4,15$ 评注:表单验证时很实用 匹配国内电话号码:d3-d8|d4-d7 评注:匹配形式如 0511-* 或 021-* 匹配腾讯QQ号:1-90-94, 评注:腾讯QQ号从10000开始 匹配中国邮政编码:1-9d5(?!d) 评注:中国邮政编码为6位数字 匹配身份证:
3、d15|d18 评注:中国的身份证为15位或18位 匹配ip地址:d+.d+.d+.d+ 评注:提取ip地址时有用 匹配特定数字: 1-9d*$ /匹配正整数 -1-9d*$ /匹配负整数 -?1-9d*$ /匹配整数 1-9d*|0$ /匹配非负整数 -1-9d*|0$ /匹配非正整数 1-9d*.d*|0.d*1-9d*$ /匹配正浮点数 -(1-9d*.d*|0.d*1-9d*)$ /匹配负浮点数 -?(1-9d*.d*|0.d*1-9d*|0?.0+|0)$ /匹配浮点数 1-9d*.d*|0.d*1-9d*|0?.0+|0$ /匹配非负浮点数 (-(1-9d*.d*|0.d*1-9d
4、*)|0?.0+|0$/匹配非正浮点数 评注:处理大量数据时有用,具体应用时注意修正 匹配特定字符串: A-Za-z+$/匹配由26个英文字母组成的字符串 A-Z+$/匹配由26个英文字母的大写组成的字符串 a-z+$/匹配由26个英文字母的小写组成的字符串 A-Za-z0-9+$/匹配由数字和26个英文字母组成的字符串 w+$/匹配由数字、26个英文字母或者下划线组成的字符串 在使用RegularExpressionValidator验证控件时的验证功能及其验证表达式介绍如下: 只能输入数字:“0-9*$” 只能输入n位的数字:“dn$” 只能输入至少n位数字:“dn,$” 只能输入m-n位
5、的数字:“dm,n$” 只能输入零和非零开头的数字:“(0|1-90-9*)$” 只能输入有两位小数的正实数:“0-9+(.0-92)?$” 只能输入有1-3位小数的正实数:“0-9+(.0-91,3)?$” 只能输入非零的正整数:“+?1-90-9*$” 只能输入非零的负整数:“-1-90-9*$” 只能输入长度为3的字符:“.3$” 只能输入由26个英文字母组成的字符串:“A-Za-z+$” 只能输入由26个大写英文字母组成的字符串:“A-Z+$” 只能输入由26个小写英文字母组成的字符串:“a-z+$” 只能输入由数字和26个英文字母组成的字符串:“A-Za-z0-9+$” 只能输入由数
6、字、26个英文字母或者下划线组成的字符串:“w+$” 验证用户密码:“a-zA-Zw5,17$”正确格式为:以字母开头,长度在6-18之间, 只能包含字符、数字和下划线。 验证是否含有%&,;=?$等字符:“%&,;=?$x22+” 只能输入汉字:“u4e00-u9fa5,0,$” 验证Email地址:“w+-+.w+)*w+(-.w+)*.w+(-.w+)*$” 验证InternetURL:“http:/(w-+.)+w-+(/w-./?%&=*)?$” 验证电话号码:“(d3,4)|d3,4-)?d7,8$” 正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XX
7、X-XXXXXXX”, “XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。 验证身份证号:“d15|d18$” 验证一年的12个月:“(0?1-9|10-2)$”正确格式为:“01”-“09”和“1”“12” 验证一个月的31天:“(0?1-9)|(1|2)0-9)|30|31)$” 正确格式为:“01”“09”和“1”“31”。 匹配中文字符的正则表达式: u4e00-u9fa5 匹配双字节字符(包括汉字在内):x00-xff 匹配空行的正则表达式:ns| *r 匹配HTML标记的正则表达式:/<(.*)>.*|<(.*) />/ 匹配首尾空格的正则表达
8、式:(s*)|(s*$) 匹配Email地址的正则表达式:w+(-+.w+)*w+(-.w+)*.w+(-.w+)* 匹配网址URL的正则表达式:http:/(w-+.)+w-+(/w- ./?%&=*)? (1)应用:计算字符串的长度 String.prototype.len=functionreturn this.replace(x00-xff/g,aa).length; (2)应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现 String.prototype.trim = function return this.replace(/(s
9、*)|(s*$)/g, ); (3)应用:利用正则表达式分解和转换IP地址 function IP2V(ip) /IP地址转换成对应数值 re=/(d+).(d+).(d+).(d+)/g /匹配IP地址的正则表达式 if(re.test(ip) return RegExp.$1*Math.pow(255,3)+RegExp.$2*Math.pow(255,2)+RegExp.$3*255+RegExp.$4*1 else throw new Error(Not a valid IP address!) (4)应用:从URL地址中提取文件名的javascript程序 s= s=s.replac
10、e(/(.*/)0,(.+).*/ig,$2) ;/Page1.htm (5)应用:利用正则表达式限制网页表单里的文本框输入内容 用正则表达式限制只能输入中文:onkeyup=value=value.replace(/u4E00-u9FA5/g,) onbeforepaste=clipboardData.setData(text,clipboardData.getData(text).replace(/u4E00-u9FA5/g,) 用正则表达式限制只能输入全角字符: onkeyup=value=value.replace(/uFF00-uFFFF/g,) onbeforepaste=clip
11、boardData.setData(text,clipboardData.getData(text).replace(/uFF00-uFFFF/g,) 用正则表达式限制只能输入数字:onkeyup=value=value.replace(/d/g,) onbeforepaste= clipboardData.setData(text,clipboardData.getData(text).replace(/d/g,) 用正则表达式限制只能输入数字和英文:onkeyup=value=value.replace(/W/g,) onbeforepaste=clipboardData.setData(
12、text,clipboardData.getData(text).replace(/d/g,首先在正则表达式中使用 Unicode,必须使用u开头,接着是字符编码的四位16进制表现形式简单匹配中文方法: /u0000-u00FF/ (匹配非单字节字符 )另错误方法:/u00-uFF/ (匹配 非单字节字符、还包括一些全半角符号如,.!等、还有vwxyz字符)说明: /u0000-u00ff.包含unicode单字节编码包含基本控制字符和拉丁文字母。 采用该否定表达式,粗略判断是否含有中文。具体的匹配中文及字符方法:/u4E00-u9FA5uF900-uFA2D/说明: u4e00-u9fbf : unicode CJK(中日韩)统一表意字符。u9fa5后至u9fbf为空 uF900-uFAFF : 为unicode CJK 兼容象形文字 。uFA2D后至uFAFF为空