C#語法:正則表達式 --Trim()的實現

正則表達式匹配輸入文本的模式

常用元字符

代碼 說明
.                      匹配除換行符以外的任意字符。
\w 匹配字母或數字或下劃線或漢字。
\s  匹配任意的空白符。
\d 匹配數字。
\b 匹配單詞的開始或結束。
[ck] 匹配包含括號內元素的字符
^ 匹配行的開始。
匹配行的結束。
\ 對下一個字符轉義。比如$是個特殊的字符。要匹配$的話就得用\$
| 分支條件,如:x|y匹配 x 或 y。

反義元字符

代碼 說明
\W              匹配任意不是字母,數字,下劃線,漢字的字符。
\S 匹配任意不是空白符的字符。等價於 [^ \f\n\r\t\v]。
\D 匹配任意非數字的字符。等價於 [^0-9]。
\B 匹配不是單詞開頭或結束的位置。
[^CK]  匹配除了CK以外的任意字符。

特殊元字符

代碼 說明
\f             匹配一個換頁符。等價於 \x0c 和 \cL。
\n 匹配一個換行符。等價於 \x0a 和 \cJ。
\r 匹配一個回車符。等價於 \x0d 和 \cM。
\t 匹配一個製表符。等價於 \x09 和 \cI。
\v 匹配一個垂直製表符。等價於 \x0b 和 \cK。

限定符

代碼 說明
*                       匹配前面的子表達式零次或多次。
+ 匹配前面的子表達式一次或多次。
? 匹配前面的子表達式零次或一次。
{n} n 是一個非負整數。匹配確定的 n 次。
{n,} n 是一個非負整數。至少匹配n 次。
{n,m} m 和 n 均爲非負整數,其中n <= m。最少匹配 n 次且最多匹配 m 次。

懶惰限定符

代碼 說明
*?                                                 

重複任意次,但儘可能少重複。

如 "acbacb"  正則  "a.*?b" 只會取到第一個"acb" 原本可以全部取到但加了限定符後,只會匹配儘可能少的字符 ,而"acbacb"最少字符的結果就是"acb" 。

+? 重複1次或更多次,但儘可能少重複。與上面一樣,只是至少要重複1次。
??

重複0次或1次,但儘可能少重複。

如 "aaacb" 正則 "a.??b" 只會取到最後的三個字符"acb"。

{n,m}?

重複n到m次,但儘可能少重複。

如 "aaaaaaaa"  正則 "a{0,m}" 因爲最少是0次所以取到結果爲空。

{n,}?

重複n次以上,但儘可能少重複。

如 "aaaaaaa"  正則 "a{1,}" 最少是1次所以取到結果爲 "a"。

捕獲分組

代碼 說明
(exp)                                                  匹配exp,並捕獲文本到自動命名的組裏。
(?<name>exp) 匹配exp,並捕獲文本到名稱爲name的組裏。
(?:exp) 匹配exp,不捕獲匹配的文本,也不給此分組分配組號以下爲零寬斷言。
(?=exp)

匹配exp前面的位置。

如 "How are you doing" 正則"(?<txt>.+(?=ing))" 這裏取ing前所有的字符,並定義了一個捕獲分組名字爲 "txt" 而"txt"這個組裏的值爲"How are you do";

(?<=exp)

匹配exp後面的位置。

如 "How are you doing" 正則"(?<txt>(?<=How).+)" 這裏取"How"之後所有的字符,並定義了一個捕獲分組名字爲 "txt" 而"txt"這個組裏的值爲" are you doing";

(?!exp)

匹配後面跟的不是exp的位置。

如 "123abc" 正則 "\d{3}(?!\d)"匹配3位數字後非數字的結果

(?<!exp)

匹配前面不是exp的位置。

如 "abc123 " 正則 "(?<![0-9])123" 匹配"123"前面是非數字的結果也可寫成"(?!<\d)123"


參考:http://www.runoob.com/csharp/csharp-regular-expressions.html

我們先用例子來說明吧。

在C#中,用正則需要引入命名空間 System.Text.RegularExpressions

private static string Trim(string str)
        {
            return System.Text.RegularExpressions.Regex.Match(str, @"\S.*\S|\S").ToString();          
        }

Match():搜索第一個匹配項。

這段代碼是用一句話用正則表達式來實現刪除字符串兩端空白。其中 @ 符號作用防止轉義。對照上面表,'\S'爲匹配非空格字符, ' .  '爲任意字符,和 '*'搭配,'.*'則爲任意字符串。實現此功能的思路就是:當字符串字母個數大於1時第一個字符爲非空白符,最後一個字符爲非空白符,中間爲任意字符串。當字母個數爲1時,直接獲取那個字母就行。

又例如:

 var arrstr = Regex.Matches(" hahha90687h987f87 ", @"\S[^0-9]*\S");
            Console.WriteLine(@" hahha90687h987f87 :");
            foreach (var s in arrstr)
            {
                Console.WriteLine(s);
            }

輸出結果


[^0-9]:是匹配不是0到9的字符,和\D是一樣的效果(注意是 '-'號而不是'~'號)

又例如:

var arrstr = Regex.Matches("hello.txt world.doc ", @".*[.]txt");
            Console.WriteLine(@"hello.txt world.doc:");
            foreach (var s in arrstr)
            {
                Console.WriteLine(s);
            }

[.]:代表匹配方括號內的'.'字符


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