抄袭正则表达式来

Posted Blogger

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了抄袭正则表达式来相关的知识,希望对你有一定的参考价值。

 数字:^[0-9]*$
 n位的数字:^\\d{n}$
 至少n位的数字:^\\d{n,}$
 m-n位的数字:^\\d{m,n}$
 零和非零开头的数字:^(0|[1-9][0-9]*)$
 非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$
 带1-2位小数的正数或负数:^(\\-)?\\d+(\\.\\d{1,2})?$
 正数、负数、和小数:^(\\-|\\+)?\\d+(\\.\\d+)?$
 有两位小数的正实数:^[0-9]+(.[0-9]{2})?$
 有1~3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$
 非零的正整数:^[1-9]\\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\\+?[1-9][0-9]*$
 非零的负整数:^\\-[1-9][]0-9"*$ 或 ^-[1-9]\\d*$
 非负整数:^\\d+$ 或 ^[1-9]\\d*|0$
 非正整数:^-[1-9]\\d*|0$ 或 ^((-\\d+)|(0+))$
 非负浮点数:^\\d+(\\.\\d+)?$ 或 ^[1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*|0?\\.0+|0$
 非正浮点数:^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$ 或 ^(-([1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*))|0?\\.0+|0$
 正浮点数:^[1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*$ 或 ^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$
 负浮点数:^-([1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*)$ 或 ^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
 浮点数:^(-?\\d+)(\\.\\d+)?$ 或 ^-?([1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*|0?\\.0+|0)$

二、校验字符的表达式

 汉字:^[\\u4e00-\\u9fa5]{0,}$
 英文和数字:^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
 长度为3-20的所有字符:^.{3,20}$
 由26个英文字母组成的字符串:^[A-Za-z]+$
 由26个大写英文字母组成的字符串:^[A-Z]+$
 由26个小写英文字母组成的字符串:^[a-z]+$
 由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
 由数字、26个英文字母或者下划线组成的字符串:^\\w+$ 或 ^\\w{3,20}$
 中文、英文、数字包括下划线:^[\\u4E00-\\u9FA5A-Za-z0-9_]+$
 中文、英文、数字但不包括下划线等符号:^[\\u4E00-\\u9FA5A-Za-z0-9]+$ 或 ^[\\u4E00-\\u9FA5A-Za-z0-9]{2,20}$
 可以输入含有^%&\',;=?$\\"等字符:[^%&\',;=?$\\x22]+
 禁止输入含有~的字符:[^~\\x22]+

三、特殊需求表达式

Email地址:^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$
 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
 InternetURL:[a-zA-z]+://[^\\s]* 或 ^http://([\\w-]+\\.)+[\\w-]+(/[\\w-./?%&=]*)?$
 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\\d{8}$
 电话号码("XXX-XXXXXXX""XXXX-XXXXXXXX""XXX-XXXXXXX""XXX-XXXXXXXX""XXXXXXX""XXXXXXXX):^(\\(\\d{3,4}-)|\\d{3.4}-)?\\d{7,8}$ 
 国内电话号码(0511-4405222021-87888822):\\d{3}-\\d{8}|\\d{4}-\\d{7}
 身份证号(15位、18位数字):^\\d{15}|\\d{18}$
 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)?$ 或 ^\\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\\w{5,17}$
 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.*\\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$  
 日期格式:^\\d{4}-\\d{1,2}-\\d{1,2}
 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$ 
 钱的输入格式:
    1.有四种钱的表示形式我们可以接受:"10000.00""10,000.00", 和没有 """10000""10,000":^[1-9][0-9]*$ 
    2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符"0"不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$ 
    3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$ 
    4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$ 
    5.必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的,但是 "10""10.2" 是通过的:^[0-9]+(.[0-9]{2})?$ 
    6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$ 
    7.这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$ 
    8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$ 
    备注:这就是最终结果了,别忘了"+"可以用"*"替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
 xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\\\.[x|X][m|M][l|L]$
 中文字符的正则表达式:[\\u4e00-\\u9fa5]
 双字节字符:[^\\x00-\\xff]    (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
 空白行的正则表达式:\\n\\s*\\r    (可以用来删除空白行)
 html标记的正则表达式:<(\\S*?)[^>]*>.*?</\\1>|<.*? />    (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
 首尾空白字符的正则表达式:^\\s*|\\s*$或(^\\s*)|(\\s*$)    (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
 腾讯QQ号:[1-9][0-9]{4,}    (腾讯QQ号从10000开始)
 中国邮政编码:[1-9]\\d{5}(?!\\d)    (中国邮政编码为6位数字)
 IP地址:\\d+\\.\\d+\\.\\d+\\.\\d+    (提取IP地址时有用)
 IP地址:((?:(?:25[0-5]|2[0-4]\\\\d|[01]?\\\\d?\\\\d)\\\\.){3}(?:25[0-5]|2[0-4]\\\\d|[01]?\\\\d?\\\\d))    (由@飞龙三少 提供,感谢共享)

 

源文:http://www.cnblogs.com/zxin/archive/2013/01/26/2877765.html  最全的常用正则表达式大全——包括校验数字、字符、一些特殊的需求等等

 

抄袭二:

正则

1 . 修饰词

 ```
  i  :匹配时忽略大小写
  g : 匹配时全局匹配,查找所有匹配项,而非查找到一个既停止
```

2 . 匹配模式
方括号
---方括号用于查找某个范围内的字符:

表达式描述
[abc] 查找方括号之间的任何字符。
[^abc] 查找任何不在方括号之间的字符。
[0-9] 查找任何从 0 至 9 的数字。
[a-z] 查找任何从小写 a 到小写 z 的字符。
[A-Z] 查找任何从大写 A 到大写 Z 的字符。
[A-z] 查找任何从大写 A 到小写 z 的字符。
[adgk] 查找给定集合内的任何字符。
[^adgk] 查找给定集合外的任何字符。
(red&|blue&|green)    查找任何指定的选项。

元字符
----元字符(Metacharacter)是拥有特殊含义的字符:

元字符描述
. 查找单个字符,除了换行和行结束符。
\\w 查找单词字符。
\\W 查找非单词字符。
\\d 查找数字。
\\D 查找非数字字符。
\\s 查找空白字符。
\\S 查找非空白字符。
\\b 匹配单词边界。
\\B 匹配非单词边界。
\\0 查找 NUL 字符。
\\n 查找换行符。
\\f 查找换页符。
\\r 查找回车符。
\\t 查找制表符。
\\v 查找垂直制表符。
\\xxx 查找以八进制数 xxx 规定的字符。
\\xdd 查找以十六进制数 dd 规定的字符。
\\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

量词描述
n+ 匹配任何包含至少一个 n 的字符串。
n* 匹配任何包含零个或多个 n 的字符串。
n? 匹配任何包含零个或一个 n 的字符串。
n{X} 匹配包含 X 个 n 的序列的字符串。
n{X,Y} 匹配包含 X 或 Y 个 n 的序列的字符串。
n{X,} 匹配包含至少 X 个 n 的序列的字符串。
n$ 匹配任何结尾为 n 的字符串。
^n 匹配任何开头为 n 的字符串。
?=n 匹配任何其后紧接指定字符串 n 的字符串。
?!n 匹配任何其后没有紧接指定字符串 n 的字符串。

RegExp 对象方法

方法描述
compile 编译正则表达式。
exec 检索字符串中指定的值。返回找到的值,并确定其位置。
test 检索字符串中指定的值。返回 true 或 false。

支持正则表达式的 String 对象的方法

方法描述
search 检索与正则表达式相匹配的值。
match 找到一个或多个正则表达式的匹配。
replace 替换与正则表达式匹配的子串。
split 把字符串分割为字符串数组。

常用正则表达式

整数或者小数:^[0-9]+\\.{0,1}[0-9]{0,2}$
只能输入数字:"^[0-9]*$"。
只能输入n位的数字:"^\\d{n}$"。
只能输入至少n位的数字:"^\\d{n,}$"。
只能输入m~n位的数字:。"^\\d{m,n}$"
只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
只能输入非零的正整数:"^\\+?[1-9][0-9]*$"。
只能输入非零的负整数:"^\\-[1-9][]0-9"*$。
只能输入长度为3的字符:"^.{3}$"。
只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
只能输入由数字、26个英文字母或者下划线组成的字符串:"^\\w+$"。
验证用户密码:"^[a-zA-Z]\\w{5,17}$"正确格式为:以字母开头,长度在6~18之间,只能包含字符、数字和下划线。
验证是否含有^%&\',;=?$\\"等字符:"[^%&\',;=?$\\x22]+"。
只能输入汉字:"^[\\u4e00-\\u9fa5]{0,}$"
验证Email地址:"^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$"。
验证InternetURL:"^http://([\\w-]+\\.)+[\\w-]+(/[\\w-./?%&=]*)?$"。
验证电话号码:"^(\\(\\d{3,4}-)|\\d{3.4}-)?\\d{7,8}$"正确格式为:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。
验证身份证号(15位或18位数字):"^\\d{15}|\\d{18}$"。
验证一年的12个月:"^(0?[1-9]|1[0-2])$"正确格式为:"01"~"09"和"1"~"12"。
验证一个月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正确格式为;"01"~"09"和"1"~"31"。 匹配中文字符的正则表达式: [\\u4e00-\\u9fa5]
匹配双字节字符(包括汉字在内):[^\\x00-\\xff]
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace(/[^\\x00-\\xff]/g,"aa").length;}
匹配空行的正则表达式:\\n[\\s| ]*\\r
匹配html标签的正则表达式:<(.*)>(.*)<\\/(.*)>|<(.*)\\/>
匹配首尾空格的正则表达式:(^\\s*)|(\\s*$)
 判断邮箱:
var reg = /^\\w+@\\w+(\\.(com|cn|net|org|edu)){1,2}$/g;
判断手机号:
var reg = /^((13|18)(\\d{9}))$|^(14[57]\\d{8})$|^(17[07]\\d{8})$|(^15[0-35-9]\\d{8}$)/;
判断小数:
var reg = /^\\d+\\.\\d+$/g;
判断后缀:
var reg = /^.+\\.pdf$/i;
判断纯数字:
var reg = /^\\d+$/g;
判断IP地址:^([1-9]|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5])(\\.(\\d|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5])){3}$

匹配中文字符的正则表达式: [\\u4e00-\\u9fa5]
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了

匹配双字节字符(包括汉字在内):[^\\x00-\\xff]
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

匹配空白行的正则表达式:\\n\\s*\\r
评注:可以用来删除空白行

匹配HTML标记的正则表达式:<(\\S*?)[^>]*>.*?|<.*? />
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力

匹配首尾空白字符的正则表达式:^\\s*|\\s*$
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式

匹配Email地址的正则表达式:\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*
评注:表单验证时很实用

匹配网址URL的正则表达式:[a-zA-z]+://[^\\s]*
评注:网上流传的版本功能很有限,上面这个基本可以满足需求

匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注:表单验证时很实用

匹配国内电话号码:\\d{3}-\\d{8}|\\d{4}-\\d{7}
评注:匹配形式如 0511-4405222 或 021-87888822

匹配腾讯QQ号:[1-9][0-9]{4,}
评注:腾讯QQ号从10000开始

匹配中国邮政编码:[1-9]\\d{5}(?!\\d)
评注:中国邮政编码为6位数字

匹配身份证:\\d{15}|\\d{18}
评注:中国的身份证为15位或18位

匹配ip地址:\\d+\\.\\d+\\.\\d+\\.\\d+
评注:提取ip地址时有用

匹配特定数字:
^[1-9]\\d*$    //匹配正整数
^-[1-9]\\d*$   //匹配负整数
^-?[1-9]\\d*$   //匹配整数
^[1-9]\\d*|0$  //匹配非负整数(正整数 + 0)
^-[1-9]\\d*|0$   //匹配非正整数(负整数 + 0)
^[1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*$   //匹配正浮点数
^-([1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*)$  //匹配负浮点数
^-?([1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*|0?\\.0+|0)$  //匹配浮点数
^[1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*|0?\\.0+|0$   //匹配非负浮点数(正浮点数 + 0)
^(-([1-9]\\d*\\.\\d*|0\\.\\d*[1-9]\\d*))|0?\\.0+|0$  //匹配非正浮点数(负浮点数 + 0)
评注:处理大量数据时有用,具体应用时注意修正

匹配特定字符串:
^[A-Za-z]+$  //匹配由26个英文字母组成的字符串
^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串
^[a-z]+$  //匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串
^\\w+$  //匹配由数字、26个英文字母或者下划线组成的字符串
评注:最基本也是最常用的一些表达式

整理出来的一些常用的正则表达式所属分类: JScript  (三)
Email : /^\\w+([-+.]\\w+)*@\\w+([-.]\\\\w+)*\\.\\w+([-.]\\w+)*$/
isEmail1 : /^\\w+([\\.\\-]\\w+)*\\@\\w+([\\.\\-]\\w+)*\\.\\w+$/;
isEmail2 : /^.*@[^_]*$/;
Phone : /^((\\(\\d{3}\\))|(\\d{3}\\-))?(\\(0\\d{2,3}\\)|0\\d{2,3}-)?[1-9]\\d{6,7}$/
Mobile : /^((\\(\\d{3}\\))|(\\d{3}\\-))?13\\d{9}$/
Url : /^http:\\/\\/[A-Za-z0-9]+\\.[A-Za-z0-9]+[\\/=\\?%\\-&_~`@[\\]\\\':+!]*([^<>\\"\\"])*$/
IdCard : /^\\d{15}(\\d{2}[A-Za-z0-9])?$/
Currency : /^\\d+(\\.\\d+)?$/
Number : /^\\d+$/
Code : /^[1-9]\\d{5}$/
QQ : /^[1-9]\\d{4,8}$/
Integer : /^[-\\+]?\\d+$/
Double : /^[-\\+]?\\d+(\\.\\d+)?$/
English : /^[A-Za-z]+$/
Chinese : /^[\\u0391-\\uFFE5]+$/
UnSafe : /^(([A-Z]*|[a-z]*|\\d*|[-_\\~!@#\\$%\\^&\\*\\.\\(\\)\\[\\]\\{\\}<>\\?\\\\\\/\\\'\\"]*)|.{0,5})$|\\s/
PassWord :^[\\\\w]{6,12}$
ZipCode : ^[\\\\d]{6}
/^(\\+\\d+ )?(\\(\\d+\\) )?[\\d ]+$/; //这个是国际通用的电话号码判断
/^(1[0-2]\\d|\\d{1,2})$/; //这个是年龄的判断
/^\\d+\\.\\d{2}$/;  //这个是判断输入的是否为货币值

应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^\\x00-\\xff]/g,"aa").length;}
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
String.prototype.trim = function()
{
    return this.replace(/(^\\s*)|(\\s*$)/g, "");
}
匹配空行的正则表达式:\\n[\\s| ]*\\r
匹配HTML标记的正则表达式:/<(.*)>.*<\\/\\1>|<(.*) \\/>/
匹配首尾空格的正则表达式:(^\\s*)|(\\s*$)
匹配Email地址的正则表达式:\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*
匹配网址URL的正则表达式:http://([\\w-]+\\.)+[\\w-]+(/[\\w- ./?%&=]*)?

^\\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+)?$
 
下表是元字符及其在正则表达式上下文中的行为的一个完整列表,具体到每个正则表达式符号: 
\\ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个后向引用、或一个八进制转义符。
^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的Multiline 属性,^ 也匹配 ’\\n’ 或 ’\\r’ 之后的位置。
$ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的Multiline 属性,$ 也匹配 ’\\n’ 或 ’\\r’ 之前的位置。
* 匹配前面的子表达式零次或多次。 
+ 匹配前面的子表达式一次或多次。+ 等价于 {1,}。 
? 匹配前面的子表达式零次或一次。? 等价于 {0,1}。
{n} n 是一个非负整数,匹配确定的n 次。 
{n,} n 是一个非负整数,至少匹配n 次。 
{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。在逗号和两个数之间不能有空格。
? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。
. 匹配除 "\\n" 之外的任何单个字符。要匹配包括 ’\\n’ 在内的任何字符,请使用象 ’[.\\n]’ 的模式。
(pattern) 匹配pattern 并获取这一匹配。 (?:pattern) 匹配pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。 (?=pattern) 正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。 (?!pattern) 负向预查,与(?=pattern)作用相反 x|y 匹配 x 或 y。
[xyz] 字符集合。 
[^xyz] 负值字符集合。
[a-z] 字符范围,匹配指定范围内的任意字符。
[^a-z] 负值字符范围,匹配任何不在指定范围内的任意字符。
\\b 匹配一个单词边界,也就是指单词和空格间的位置。 
\\B 匹配非单词边界。
\\cx 匹配由x指明的控制字符。 
\\d 匹配一个数字字符。等价于 [0-9]。 
\\D 匹配一个非数字字符。等价于 [^0-9]。
 \\f 匹配一个换页符。等价于 \\x0c 和 \\cL。 
\\n 匹配一个换行符。等价于 \\x0a 和 \\cJ。 
\\r 匹配一个回车符。等价于 \\x0d 和 \\cM。 
\\s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于[ \\f\\n\\r\\t\\v]。
\\S 匹配任何非空白字符。等价于 [^ \\f\\n\\r\\t\\v]。
\\t 匹配一个制表符。等价于 \\x09 和 \\cI。
\\v 匹配一个垂直制表符。等价于 \\x0b 和 \\cK。 
\\w 匹配包括下划线的任何单词字符。等价于’[A-Za-z0-9_]’。
\\W 匹配任何非单词字符。等价于 ’[^A-Za-z0-9_]’。
\\xn 匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长。
\\num 匹配 num,其中num是一个正整数。对所获取的匹配的引用。
\\n 标识一个八进制转义值或一个后向引用。如果 \\n 之前至少 n 个获取的子表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。
\\nm 标识一个八进制转义值或一个后向引用。如果 \\nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 \\nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 \\nm 将匹配八进制转义值 nm。 \\nml 如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八.

 

匹配金额的正则表达式
using System.Text.RegularExpressions;
public  bool IsPrize(string str)
        {
            //带两位小数
            Regex objRegex = new Regex(@"^([1-9]\\d{0,9}|0)(\\.\\d{1,2})?$");
            return objRegex.IsMatch(str);
        }

//参考:https://zhuanlan.zhihu.com/p/40206059?from_voters_page=true

 

      var regex = new Regex(@"^([0-9]{17}[0-9X]{1})|([0-9]{15})$");
                    if (!regex.IsMatch(request.ReceiveIdCard))
                    {
                        return new SubOrderResponse
                        {
                            ErrorMsg = "身份证格式不正确!",
                            Success = false,
                        };
                    }

 



链接:http://www.jianshu.com/p/4fb6354708e6  JS---正则表达式/常用JS正则表达式

以上是关于抄袭正则表达式来的主要内容,如果未能解决你的问题,请参考以下文章

text 正则表达式片段

markdown 正则表达式模式片段

正则表达式匹配特定的 URL 片段而不是所有其他 URL 可能性

从正则表达式的iUs说说模式修正符

循环通过 python 正则表达式匹配

asp.net 使用正则表达式验证包含打开/关闭括号片段的属性字符串