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成員:
(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 \d的補集(以所以字元為全集,下同),即所有非數字的字元
\w 單詞字元,指大小寫字母、0-9的數字、下劃線
\W \w的補集
\s 空白字元,包括換行符\n、回車符\r、製表符\t、垂直製表符\v、換頁符\f
\S \s的補集
. 除換行符\n外的任意字元
[…] 匹配[]內所列出的所有字元
[^…] 匹配非[]內所列出的字元
(3)定位字元
“定位字元”所代表的是一個虛的字元,它代表一個位置,你也可以直觀地認為“定位字元”所代表的是某個字元與字元間的那個微小間隙。
^ 表示其後的字元必須位於字串的開始處
$ 表示其前面的字元必須位於字串的結束處
\b 匹配一個單詞的邊界
\B 匹配一個非單詞的邊界
(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