1. 程式人生 > 實用技巧 >C#正則表示式

C#正則表示式

usingSystem;
usingSystem.Collections.Generic;
usingSystem.Linq;
usingSystem.Text;
usingSystem.Threading.Tasks;
usingSystem.Text.RegularExpressions;//引用名稱空間
namespaceConsoleApplication1
{
classProgram
{
staticvoidMain(string[]args)
{
stringstr="zhangdizhangdi";
stringpattren=@"zhangdi";//模式(@:逐字字串)
MatchCollectionmc=Regex.Matches(str,pattren,RegexOptions.IgnoreCase);
foreach(Matchiteminmc)
{
Console.WriteLine(item.Value+","+item.Index);
}
Console.ReadKey();
}
}
}

RegexOptions成員:

wKiom1PzdKTA36YtAAKmXKyP9bg997.jpg

(1)“@”符號
符下兩ows表研究室的火熱,當晨在“@”雖然並非C#正則表示式的“成員”,但是它經常與C#正則表示式出雙入對。“@”表示,跟在它後面的字串是個“逐字字串”,不是很好理解,舉個例子,以下兩個宣告是等效的:
string x="D:\\My Huang\\My Doc";
string y = @"D:\My Huang\My Doc";
事實上,如果按如下宣告,C#將會報錯,因為“\”在C#中用於實現轉義,如“\n”換行:
string x = "D:\My Huang\My Doc";

(2)基本的語法字元。

\d 0-9的數字
\D \d的補集(以所以字元為全集,下同),即所有非數字的字元
\w 單詞字元,指大小寫字母、0-9的數字、下劃線
\W \w的補集
\s 空白字元,包括換行符\n、回車符\r、製表符\t、垂直製表符\v、換頁符\f
\S \s的補集
. 除換行符\n外的任意字元
[…] 匹配[]內所列出的所有字元
[^…] 匹配非[]內所列出的字元

(3)定位字元
“定位字元”所代表的是一個虛的字元,它代表一個位置,你也可以直觀地認為“定位字元”所代表的是某個字元與字元間的那個微小間隙。
^ 表示其後的字元必須位於字串的開始處
$ 表示其前面的字元必須位於字串的結束處
\b 匹配一個單詞的邊界
\B 匹配一個非單詞的邊界

另外,還包括:\A 前面的字元必須位於字元處的開始處,\z 前面的字元必須位於字串的結束處,\Z 前面的字元必須位於字串的結束處,或者位於換行符前

(4)重複描述字元
“重複描述字元”是體現C#正則表示式“很好很強大”的地方之一:
{n} 匹配前面的字元n次
{n,} 匹配前面的字元n次或多於n次
{n,m} 匹配前面的字元n到m次
? 匹配前面的字元0或1次
+ 匹配前面的字元1次或多於1次
* 匹配前面的字元0次或式於0次

參考文件:

http://www.cnblogs.com/KissKnife/archive/2008/03/23/1118423.html

http://www.wangqi.com/n9250c53.aspx

轉載於:https://blog.51cto.com/962410314/1542288