C# 正则表达式笔记

基本符号:

^  表示匹配字符串的开始位置  (例外  用在中括号中[ ] 时,可以理解为取反,表示不匹配括号中字符串)
$  表示匹配字符串的结束位置
*  表示匹配 零次到多次
+  表示匹配 一次到多次 (至少有一次)
?  表示匹配零次或一次
.  表示匹配单个字符 
|  表示为或者,两项中取一项
(  ) 小括号表示匹配括号中全部字符
[  ] 中括号表示匹配括号中一个字符 范围描述 如[0-9 a-z A-Z]
{  } 大括号用于限定匹配次数  如 {n}表示匹配n个字符  {n,}表示至少匹配n个字符  {n,m}表示至少n,最多m
\  转义字符 如上基本符号匹配都需要转义字符   如 \*  表示匹配*号
\w 表示英文字母和数字  \W  非字母和数字
\d  表示数字   \D  非数字
其中:

01,      数字与非数字

数字:\d

非数字:\D

02,空字符与非空字符

          空字符:\s

       非空字符;\S

         可以匹配空格和换行

03,文字与非文字

  文字(数字,字母和汉字,不包含标点符号):

   文字:\w

  非文字:\W

.Net中的正则表达式

 在.Net中我们使用Regex类来书写正则表达式

Regex的常用方法:

IsMatch():判断是否匹配

Match():字符串提取

Matches():循环提取

Replace():Replace()

其中Match和Matches功能一样,只是Match取的是第一个

 

 

 利用 (?<xxx>子表达式) 定义分组别名,这样就可以利用 Groups["xxx"] 进行访问分组/子表达式内容。

 

 

 

常用的正则表达式

匹配中文字符的正则表达式: [\u4e00-\u9fa5]
 
匹配双字节字符(包括汉字在内):[^\x00-\xff]
 
匹配空行的正则表达式:\n[\s| ]*\r
 
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/ 
 
匹配首尾空格的正则表达式:(^\s*)|(\s*$)
 
匹配IP地址的正则表达式:/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //
 
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
 
匹配网址URL的正则表达式:http://(/[\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
 
sql语句:^(select|drop|delete|create|update|insert).*$
 
1、非负整数:^\d+$ 
 
2、正整数:^[0-9]*[1-9][0-9]*$ 
 
3、非正整数:^((-\d+)|(0+))$ 
 
4、负整数:^-[0-9]*[1-9][0-9]*$ 
 
5、整数:^-?\d+$ 
 
6、非负浮点数:^\d+(\.\d+)?$ 
 
7、正浮点数:^((0-9)+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ 
 
8、非正浮点数:^((-\d+\.\d+)?)|(0+(\.0+)?))$ 
 
9、负浮点数:^(-((正浮点数正则式)))$ 
 
10、英文字符串:^[A-Za-z]+$ 
 
11、英文大写串:^[A-Z]+$ 
 
12、英文小写串:^[a-z]+$ 
 
13、英文字符数字串:^[A-Za-z0-9]+$ 
 
14、英数字加下划线串:^\w+$ 
 
15、E-mail地址:^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$ 
 
16、URL:^[a-zA-Z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\s*)?$ 
或:^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$
 
17、邮政编码:^[1-9]\d{5}$
 
18、中文:^[\u0391-\uFFE5]+$
 
19、电话号码:^((\d2,3)|(\d{3}\-))?(0\d2,3|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
 
20、手机号码:^((\d2,3)|(\d{3}\-))?13\d{9}$
 
21、双字节字符(包括汉字在内):^\x00-\xff
 
22、匹配首尾空格:(^\s*)|(\s*$)(像vbscript那样的trim函数)
 
23、匹配HTML标记:<(.*)>.*<\/\1>|<(.*) \/> 
 
24、匹配空行:\n[\s| ]*\r
 
25、提取信息中的网络链接:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
 
26、提取信息中的邮件地址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
 
27、提取信息中的图片链接:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
 
28、提取信息中的IP地址:(\d+)\.(\d+)\.(\d+)\.(\d+)
 
29、提取信息中的中国手机号码:(86)*0*13\d{9}
 
30、提取信息中的中国固定电话号码:(\d3,4|\d{3,4}-|\s)?\d{8}
 
31、提取信息中的中国电话号码(包括移动和固定电话):(\d3,4|\d{3,4}-|\s)?\d{7,14}
 
32、提取信息中的中国邮政编码:[1-9]{1}(\d+){5}
 
33、提取信息中的浮点数(即小数):(-?\d*)\.?\d+
 
34、提取信息中的任何数字 :(-?\d*)(\.\d+)? 
 
35、IP:(\d+)\.(\d+)\.(\d+)\.(\d+)
 
36、电话区号:/^0\d{2,3}$/
 
37、腾讯QQ号:^[1-9]*[1-9][0-9]*$
 
38、帐号(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
 
39、中文、英文、数字及下划线:^[\u4e00-\u9fa5_a-zA-Z0-9]+$

 

 

 
posted @ 2019-08-27 11:01  归去如风  阅读(470)  评论(0编辑  收藏  举报