just do it

整理:正则表达式全集

正则表达式全集

中国电话号码验证

匹配形式如:0511-4405222 或者021-87888822 或者 021-44055520-555 或者 (0511)4405222

正则表达式 “((d{3,4})|d{3,4}-)?d{7,8}(-d{3})*”

中国邮政编码验证

匹配形式如:215421

正则表达式 “d{6}”

电子邮件验证

匹配形式如:justali@justdn.com

正则表达式 “w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*”

身份证验证

匹配形式如:15位或者18位身份证

正则表达式 “d{18}|d{15}”

常用数字验证

正则表达式

“d{n}” n为规定长度

“d{n,m}” n到m的长度范围

非法字符验证

匹配非法字符如:< > & / ‘ |

正则表达式 [^<>&/|’]+

日期验证

匹配形式如:20030718,030718

范围:1900–2099

正则表达式((((19){1}|(20){1})d{2})|d{2})[01]{1}d{1}[0-3]{1}d{1}

正则表达式是一个好东西,但是一般情况下,我们需要验证的内容少之又少。下面是常用的17种正则表达式:

“^d+$”  //非负整数(正整数 + 0)

“^[0-9]*[1-9][0-9]*$”  //正整数

“^((-d+)|(0+))$”  //非正整数(负整数 + 0)

“^-[0-9]*[1-9][0-9]*$”  //负整数

“^-?d+$”    //整数

“^d+(.d+)?$”  //非负浮点数(正浮点数 + 0)

“^(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*))$”  //正浮点数

“^((-d+(.d+)?)|(0+(.0+)?))$”  //非正浮点数(负浮点数 + 0)

“^(-(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*)))$”  //负浮点数

“^(-?d+)(.d+)?$”  //浮点数

“^[A-Za-z]+$”  //由26个英文字母组成的字符串

“^[A-Z]+$”  //由26个英文字母的大写组成的字符串

“^[a-z]+$”  //由26个英文字母的小写组成的字符串

“^[A-Za-z0-9]+$”  //由数字和26个英文字母组成的字符串

“^w+$”  //由数字、26个英文字母或者下划线组成的字符串

“^[w-]+(.[w-]+)*@[w-]+(.[w-]+)+$”    //email地址

“^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$”  //url

[code]电子邮件 : @”^w+((-w+)|(.w+))*@w+((.|-)w+)*.w+$”

HTTP URL : @”^[url]http://([/url][w-]+.)+[w-]+(/[w- ./?%&=]*)?”;

邮编 : @”d{6}”

身份证 : @”d{18}|d{15}”

整数 : @”^d{1,}$”

数值 : @”^-?(0|d+)(.d+)?$”

日期 : @”^(?:(?:(?:(?:1[6-9]|[2-9]d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00)))(/|-|.)(?:0?21(?:29))$)|(?:(?:1[6-9]|[2-9]d)?d{2})(/|-|.)(?:(?:(?:0?[13578]|1[02])2(?:31))|(?:(?:0?[1,3-9]|1[0-2])2(29|30))|(?:(?:0?[1-9])|(?:1[0-2]))2(?:0?[1-9]|1d|2[0-8]))$”

合法的用户名(以字母开头,长度不小于4) : @”(([a-zA-Z]){1})+(w{3,29})”[/code]
<=””>[code]常用正则表达式语法例句

这里有一些可能会遇到的正则表达式示例:

/^[ t]*$/ “^[ t]*$” 匹配一个空白行。

/d{2}-d{5}/ “d{2}-d{5}” 验证一个ID号码是否由一个2位字,一

个连字符以及一个5位数字组成。

/<(.*)>.*</1>/ “<(.*)>.*</1>” 匹配一个 HTML 标记。

下表是元字符及其在正则表达式上下文中的行为的一个完整列表:

字符 描述

将下一个字符标记为一个特殊字符、或一个原义字符、或一个 后

向引用、或一个八进制转义符。例如,’n’ 匹配字符 “n”。’n’

匹配一个换行符。序列 ” 匹配 “” 而 “(” 则匹配 “(“。

^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的

Multiline 属性,^ 也匹配 ‘n’ 或 ‘r’ 之后的位置。

$ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的

Multiline 属性,$ 也匹配 ‘n’ 或 ‘r’ 之前的位置。

* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 “z” 以及

“zoo”。 * 等价于{0,}。

+ 匹配前面的子表达式一次或多次。例如,’zo+’ 能匹配 “zo” 以

及 “zoo”,但不能匹配 “z”。+ 等价于 {1,}。

? 匹配前面的子表达式零次或一次。例如,”do(es)?” 可以匹配

“do” 或 “does” 中的”do” 。? 等价于 {0,1}。

{n} n 是一个非负整数。匹配确定的 n 次。例如,’o{2}’ 不能匹配

“Bob” 中的 ‘o’,但是能匹配 “food” 中的两个 o。

{n,} n 是一个非负整数。至少匹配n 次。例如,’o{2,}’ 不能匹配

“Bob” 中的 ‘o’,但能匹配 “foooood” 中的所有 o。’o{1,}’

等价于 ‘o+’。’o{0,}’ 则等价于 ‘o*’。

{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹

配 m 次。刘, “o{1,3}” 将匹配 “fooooood” 中的前三个o。

‘o{0,1}’等价于’o?’。请注意在逗号和两个数之间不能有空格

? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,},

{n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的

匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜

索的字符串。例如,对于字符串 “oooo”,’o+?’ 将匹配单个

“o”,而 ‘o+’ 将匹配所有 ‘o’。

. 匹配除 “n” 之外的任何单个字符。要匹配包括 ‘n’ 在内的任

何字符,请使用象 ‘[.n]’ 的模式。

(pattern) 匹配pattern 并获取这一匹配。所获取的匹配可以从产生的

点赞