正則表達式匹配輸入文本的模式
常用元字符
代碼 | 說明 |
. | 匹配除換行符以外的任意字符。 |
\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" |
我們先用例子來說明吧。
在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);
}
[.]:代表匹配方括號內的'.'字符