C#正則學習資料

 

全面剖析C#正則表達式

        到目前爲止,許多的編程語言和工具都包含對正則表達式的支持,當然.NET也不例外,.NET基礎類庫中包含有一個名稱空間和一系列可以充分發揮規則表達式威力的類。 
       
正則表達式的知識可能是不少編程人員最煩惱的事兒了。如果你還沒有規則表達式方面的知識的話,建議從正則表達式的基礎知識入手。前參見 正則表達式語法 

       
下面就來研究C#中的正則表達式,C#中的正則表達式包含在.NET基礎雷庫的一個名稱空間下,這個名稱空間就是System.Text.RegularExpressions。該名稱空間包括8個類,1個枚舉,1個委託。他們分別是:
                     Capture:
包含一次匹配的結果; 
                     CaptureCollection: Capture
的序列; 
                     Group:
一次組記錄的結果,由Capture繼承而來; 
                     GroupCollection
:表示捕獲組的集合
                     Match:
一次表達式的匹配結果,由Group繼承而來; 
                     MatchCollection: Match
的一個序列; 
                     MatchEvaluator:
執行替換操作時使用的委託; 
                     Regex
:編譯後的表達式的實例。 
                     RegexCompilationInfo
:提供編譯器用於將正則表達式編譯爲獨立程序集的信息
                     RegexOptions
提供用於設置正則表達式的枚舉值
Regex
類中還包含一些靜態的方法: 
                    Escape:
對字符串中的regex中的轉義符進行轉義; 
                    IsMatch:
如果表達式在字符串中匹配,該方法返回一個布爾值; 
                    Match:
返回Match的實例; 
                    Matches:
返回一系列的Match的方法; 
                    Replace:
用替換字符串替換匹配的表達式; 
                    Split:
返回一系列由表達式決定的字符串; 
                    Unescape:
不對字符串中的轉義字符轉義。

下面介紹他們的用途:
       
先看一個簡單的匹配例子,我們首先從使用RegexMatch類的簡單表達式開始學習。 Match m = Regex.Match("abracadabra", "(a|b|r)+"); 我們現在有了一個可以用於測試的Match類的實例,例如:if (m.Success){},如果想使用匹配的字符串,可以把它轉換成一個字符串:   MesaageBox.Show("Match="+m.ToString()); 這個例子可以得到如下的輸出: Match=abra。這就是匹配的字符串了。

        Regex
類表示只讀正則表達式類。它還包含各種靜態方法(在下面的實例中將逐一介紹),允許在不顯式創建其他類的實例的情況下使用其他正則表達式類。

       
以下代碼示例創建了 Regex 類的實例並在初始化對象時定義一個簡單的正則表達式。聲明一個Regex對象變量:Regex objAlphaPatt;,接着創建Regex對象的一個實例,並定義其規則:objAlphaPatt=new Regex("[^a-zA-Z]");

        IsMatch
方法指示 Regex 構造函數中指定的正則表達式在輸入字符串中是否找到匹配項。這是我們使用C#正則表達式時最常用的方法之一。下面的例子說明了IsMatch方法的使用:
if( !objAlphaPatt.IsMatch("testisMatchMethod"))
 lblMsg.Text = "
匹配成功";
else
 lblMsg.Text = "
匹配不成功";
這段代碼執行的結果是匹配成功
if( ! objAlphaPatt.IsMatch("testisMatchMethod7654298"))
 lblMsg.Text = "
匹配成功";
else
 lblMsg.Text = "
匹配不成功";
這段代碼執行的結果是匹配不成功

         Escape
方法表示把轉義字符作爲字符本身使用,而不再具有轉義作用,最小的元字符集(/*+?|{[()^$.# 和空白)。Replace方法則是用指定的替換字符串替換由正則表達式定義的字符模式的所有匹配項。看下面的例子,還是使用上面定義的Regex對象:objAlphaPatt.Replace("this [test] ** replace and escape" ,Regex.Escape("()"));他的返回結果是:this/(/)/(/)test/(/)/(/)/(/)/(/)/(/)replace/(/)and/(/)escape,如果不是Escape的話,則返回結果是:this()()test()()()()()replace()and()escapeUnescape 反轉由 Escape 執行的轉換,但是,Escape 無法完全反轉 Unescape

        Split
方法是把由正則表達式匹配項定義的位置將輸入字符串拆分爲一個子字符串數組。例如:
Regex r = new Regex("-"); // Split on hyphens.
string[] s = r.Split("first-second-third");
for(int i=0;i<s.Length;i++)
{
 Response.Write(s[i]+"<br>");
}

執行的結果是:
First
Second
Third

        看上去和StringSplit方法一樣,但stringSplit方法在由正則表達式而不是一組字符確定的分隔符處拆分字符串。

        Match
方法是在輸入字符串中搜索正則表達式的匹配項,並Regex 類的 Match 方法返回 Match 對象,Match 類表示正則表達式匹配操作的結果。下面的例子演示Match方法的使用,並利用Match對象的Group屬性返回Group對象:

string text = @"public string testMatchObj string s string  match ";
string pat = @"(/w+)/s+(string)";
// Compile the regular expression.
Regex r = new Regex(pat, RegexOptions.IgnoreCase);
// Match the regular expression pattern against a text string.
Match m = r.Match(text);
int matchCount = 0;
while (m.Success)
{
 Response.Write("Match"+ (++matchCount) + "<br>");
 for (int i = 1; i <= 2; i++)
 {
  Group g = m.Groups[i];
  Response.Write("Group"+i+"='" + g + "'"  + "<br>");
  CaptureCollection cc = g.Captures;
  for (int j = 0; j < cc.Count; j++)
  {
   Capture c = cc[j];
   Response.Write("Capture"+j+"='" + c + "', Position="+c.Index + "<br>");
  }
 }
 m = m.NextMatch();
}

該事例運行結果是:
Match1
Group1='public'
Capture0='public', Position=0
Group2='string'
Capture0='string', Position=7
Match2
Group1='testMatchObj'
Capture0='testMatchObj', Position=14
Group2='string'
Capture0='string', Position=27
Match3
Group1='s'
Capture0='s', Position=34
Group2='string'
Capture0='string', Position=36

        MatchCollection
類表示成功的非重疊匹配的只讀的集合,MatchCollection 的實例是由 Regex.Matches 屬性返回的,下面的實例說明了通過在輸入字符串中找到所有與Regex中指定的匹配並填充 MatchCollection

MatchCollection mc;
Regex r = new Regex("match");
mc = r.Matches("matchcollectionregexmatchs");
for (int i = 0; i < mc.Count; i++)
{
 Response.Write( mc[i].Value + " POS:" + mc[i].Index.ToString() + "<br>");
}
該實例運行的結果是:
match POS:0
match POS:20

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章