常用正则表达式二
•提取网页中的链接地址(http:\/\/\[^" ']+)
href *= *['"]*(\S+)["']* *
((http|https|ftp):(\/\/|\\\\)((\w)+[.]){1,}(net|com|cn|org|cc|tv|{1,3})(((\/[\~]*|\\[\~]*)(\w)+)|[.](\w)+)*(((([?](\w)+){1}[=]*))*((\w)+){1}([\&](\w)+[\=](\w)+)*)*) "精确匹配"
•匹配一个 HTML 标记
<(.*)>.*<\/\1> "第一个匹配的是(.*),后面的\1就引用他,所以就成了对称的"
<[^>]*> "html标记"
•从一段HTML代码中搜索其中的图片
/\/ig,"$1"
•匹配连续字符
(.)\1 匹配两个连续相同的字符,(.)\1第一个匹配的是(.),后面的\1就引用他,连起来就成了两个连续的
(.)\1\1 匹配三个连续相同的字符,如果三个连续就用(.)\1\1,后面两个\1都引用前面的(.)
•替换"asdfasldkfjlasd中的"
(/(^\)|(\[\/abc\]$)/gi,'')
•年月日的格式
/^(\d{4})-(\d{1,2})-(\d{1,2})$/ "yyyy-mm-dd"
/^(\d{4})/(\d{1,2})/(\d{1,2})$/ "yyyy/mm/dd"
(^[]{4}-(|1)-(||3))
(/^\d{4}-(|1)-({0,1}|3)$/g)
•Email邮件的格式
/^\w+((-\w+)|(\.\w+))*\@+((\.|-)+)*\.+$/
/^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)$/
/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/
/(\w)+[@]{1}(\w)+[.]{1,3}(\w)+/
•身份证
/(){15}/ "15位数字"
/^\d+$/ "全数字"
/^(\d{14}|\d{17})(\d|x)$/ "15位或18位"
•手机电话号码
/^13(\d{8})$/ "13开头,第三位为1,3,5,6,7,8,9,0,后跟8个数字"
/^(\d{3,4}-){0,1}(\d{7,8})$/ "匹配3-4位区号和横杆,7-8位市内电话号码"
/^\d{3,4}-\d{7,8}(-\d{3,4})?$/ "区号必填为3-4位的数字,区号之后用“-”与电话号码连接;电话号码为7-8位的数字;分机号码为3-4位的数字,非必填,但若填写则以“-”与电话号码相连接"
.匹配中文字符的正则表达式: [\u4e00-\u9fa5]
匹配双字节字符(包括汉字在内):[^\x00-\xff]
匹配空行的正则表达式:\n[\s| ]*\r
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/
匹配首尾空格的正则表达式:(^\s*)|(\s*$)
匹配Email地址的正则表达式:\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*
匹配网址URL的正则表达式:http://([\w-] \.) [\w-] (/[\w- ./?%&=]*)?
.Email : /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/,
Phone : /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?\d{6,7}(\-\d{1,4})?$/,
Mobile : /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/,
Url : /^http:\/\/+\.+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/,
Currency : /^\d+(\.\d+)?$/,
Number : /^\d+$/,
Zip : /^\d{5}$/,
QQ : /^\d{4,8}$/,
Integer : /^[-\+]?\d+$/,
Double : /^[-\+]?\d+(\.\d+)?$/,
English : /^+$/,
Chinese : /^[\u0391-\uFFE5]+$/,
.
匹配中文字符的正则表达式:
匹配双字节字符(包括汉字在内):[^x00-xff]
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
匹配空白行的正则表达式:ns*r
评注:可以用来删除空白行
匹配HTML标记的正则表达式:< (S*?)[^>]*>.*?|< .*? />
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力
匹配首尾空白字符的正则表达式:^s*|s*$
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式
匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
评注:表单验证时很实用
匹配网址URL的正则表达式:+://[^s]*
评注:网上流传的版本功能很有限,上面这个基本可以满足需求
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^{4,15}$
评注:表单验证时很实用
匹配国内电话号码:d{3}-d{8}|d{4}-d{7}
评注:匹配形式如 0511-4405222 或 021-87888822
匹配腾讯QQ号:{4,}
评注:腾讯QQ号从10000开始
匹配中国邮政编码:d{5}(?!d)
评注:中国邮政编码为6位数字
匹配身份证:d{15}|d{18}
评注:中国的身份证为15位或18位
匹配ip地址:d+.d+.d+.d+
评注:提取ip地址时有用
匹配特定数字:
^d*$ //匹配正整数
^-d*$ //匹配负整数
^-?d*$ //匹配整数
^d*|0$ //匹配非负整数(正整数 + 0)
^-d*|0$ //匹配非正整数(负整数 + 0)
^d*.d*|0.d*d*$ //匹配正浮点数
^-(d*.d*|0.d*d*)$ //匹配负浮点数
^-?(d*.d*|0.d*d*|0?.0+|0)$ //匹配浮点数
^d*.d*|0.d*d*|0?.0+|0$ //匹配非负浮点数(正浮点数 + 0)
^(-(d*.d*|0.d*d*))|0?.0+|0$ //匹配非正浮点数(负浮点数 + 0)
评注:处理大量数据时有用,具体应用时注意修正
匹配特定字符串:
^+$ //匹配由26个英文字母组成的字符串
^+$ //匹配由26个英文字母的大写组成的字符串
^+$ //匹配由26个英文字母的小写组成的字符串
^+$ //匹配由数字和26个英文字母组成的字符串
^w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
在使用RegularExpressionValidator验证控件时的验证功能及其验证表达式介绍如下:
只能输入数字:“^*$”
只能输入n位的数字:“^d{n}$”
只能输入至少n位数字:“^d{n,}$”
只能输入m-n位的数字:“^d{m,n}$”
只能输入零和非零开头的数字:“^(0|*)$”
只能输入有两位小数的正实数:“^+(.{2})?$”
只能输入有1-3位小数的正实数:“^+(.{1,3})?$”
只能输入非零的正整数:“^+?*$”
只能输入非零的负整数:“^-*$”
只能输入长度为3的字符:“^.{3}$”
只能输入由26个英文字母组成的字符串:“^+$”
只能输入由26个大写英文字母组成的字符串:“^+$”
只能输入由26个小写英文字母组成的字符串:“^+$”
只能输入由数字和26个英文字母组成的字符串:“^+$”
只能输入由数字、26个英文字母或者下划线组成的字符串:“^w+$”
验证用户密码:“^w{5,17}$”正确格式为:以字母开头,长度在6-18之间,
只能包含字符、数字和下划线。
验证是否含有^%&’,;=?$”等字符:“[^%&',;=?$x22]+”
只能输入汉字:“^,{0,}$”
验证Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”
验证InternetURL:“^http://(+.)++(/*)?$”
验证电话号码:“^((d{3,4})|d{3,4}-)?d{7,8}$”
正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,
“XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。
验证身份证号(15位或18位数字):“^d{15}|d{}18$”
验证一年的12个月:“^(0?|1)$”正确格式为:“01”-“09”和“1”“12”
验证一个月的31天:“^((0?)|((1|2))|30|31)$”
正确格式为:“01”“09”和“1”“31”。
匹配中文字符的正则表达式:
匹配双字节字符(包括汉字在内):[^x00-xff]
匹配空行的正则表达式:n*r
匹配HTML标记的正则表达式:/< (.*)>.*|< (.*) />/
匹配首尾空格的正则表达式:(^s*)|(s*$)
匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
匹配网址URL的正则表达式:http://(+.)++(/*)?
页:
[1]