C#语法:正则表达式 --Trim()的实现
正則表達(dá)式匹配輸入文本的模式
常用元字符
| 代碼 | 說明 |
| . ? ? ? ? ? ? ? ? ? ?? | 匹配除換行符以外的任意字符。 |
| \w | 匹配字母或數(shù)字或下劃線或漢字。 |
| \s? | 匹配任意的空白符。 |
| \d | 匹配數(shù)字。 |
| \b | 匹配單詞的開始或結(jié)束。 |
| [ck] | 匹配包含括號內(nèi)元素的字符 |
| ^ | 匹配行的開始。 |
| $? | 匹配行的結(jié)束。 |
| \ | 對下一個字符轉(zhuǎn)義。比如$是個特殊的字符。要匹配$的話就得用\$ |
| | | 分支條件,如:x|y匹配 x 或 y。 |
反義元字符
| 代碼 | 說明 |
| \W ? ? ? ? ? ?? | 匹配任意不是字母,數(shù)字,下劃線,漢字的字符。 |
| \S | 匹配任意不是空白符的字符。等價于 [^ \f\n\r\t\v]。 |
| \D | 匹配任意非數(shù)字的字符。等價于 [^0-9]。 |
| \B | 匹配不是單詞開頭或結(jié)束的位置。 |
| [^CK]? | 匹配除了CK以外的任意字符。 |
特殊元字符
| 代碼 | 說明 |
| \f ? ? ? ? ? ? | 匹配一個換頁符。等價于 \x0c 和 \cL。 |
| \n | 匹配一個換行符。等價于 \x0a 和 \cJ。 |
| \r | 匹配一個回車符。等價于 \x0d 和 \cM。 |
| \t | 匹配一個制表符。等價于 \x09 和 \cI。 |
| \v | 匹配一個垂直制表符。等價于 \x0b 和 \cK。 |
限定符
| 代碼 | 說明 |
| * ? ? ? ? ? ? ? ? ? ? ? | 匹配前面的子表達(dá)式零次或多次。 |
| + | 匹配前面的子表達(dá)式一次或多次。 |
| ? | 匹配前面的子表達(dá)式零次或一次。 |
| {n} | n 是一個非負(fù)整數(shù)。匹配確定的 n 次。 |
| {n,} | n 是一個非負(fù)整數(shù)。至少匹配n 次。 |
| {n,m} | m 和 n 均為非負(fù)整數(shù),其中n <= m。最少匹配 n 次且最多匹配 m 次。 |
懶惰限定符
| 代碼 | 說明 |
| *? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? | 重復(fù)任意次,但盡可能少重復(fù)。 如 "acbacb" ?正則 ?"a.*?b" 只會取到第一個"acb" 原本可以全部取到但加了限定符后,只會匹配盡可能少的字符 ,而"acbacb"最少字符的結(jié)果就是"acb" 。 |
| +? | 重復(fù)1次或更多次,但盡可能少重復(fù)。與上面一樣,只是至少要重復(fù)1次。 |
| ?? | 重復(fù)0次或1次,但盡可能少重復(fù)。 如 "aaacb" 正則 "a.??b" 只會取到最后的三個字符"acb"。 |
| {n,m}? | 重復(fù)n到m次,但盡可能少重復(fù)。 如 "aaaaaaaa" ?正則 "a{0,m}" 因為最少是0次所以取到結(jié)果為空。 |
| {n,}? | 重復(fù)n次以上,但盡可能少重復(fù)。 如 "aaaaaaa" ?正則 "a{1,}" 最少是1次所以取到結(jié)果為 "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位數(shù)字后非數(shù)字的結(jié)果 |
| (?<!exp) | 匹配前面不是exp的位置。 如 "abc123 " 正則 "(?<![0-9])123" 匹配"123"前面是非數(shù)字的結(jié)果也可寫成"(?!<\d)123" |
我們先用例子來說明吧。
在C#中,用正則需要引入命名空間 System.Text.RegularExpressions
private static string Trim(string str){return System.Text.RegularExpressions.Regex.Match(str, @"\S.*\S|\S").ToString(); }Match():搜索第一個匹配項。
這段代碼是用一句話用正則表達(dá)式來實現(xiàn)刪除字符串兩端空白。其中 @ 符號作用防止轉(zhuǎn)義。對照上面表,'\S'為匹配非空格字符, ' .? '為任意字符,和 '*'搭配,'.*'則為任意字符串。實現(xiàn)此功能的思路就是:當(dāng)字符串字母個數(shù)大于1時第一個字符為非空白符,最后一個字符為非空白符,中間為任意字符串。當(dāng)字母個數(shù)為1時,直接獲取那個字母就行。
又例如:
var arrstr = Regex.Matches(" hahha90687h987f87 ", @"\S[^0-9]*\S");Console.WriteLine(@" hahha90687h987f87 :");foreach (var s in arrstr){Console.WriteLine(s);}輸出結(jié)果
[^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);}[.]:代表匹配方括號內(nèi)的'.'字符
總結(jié)
以上是生活随笔為你收集整理的C#语法:正则表达式 --Trim()的实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 汇编原理实验 --计算平均数
- 下一篇: JQuery:实现列表展开和缩放