正則表達式一般包含字母文本(Literaltext)和元字符(metacharacter)
字母文本指的是普通文本如"abcde"可匹配字符串中任何包含"abcde"的字符串。javascript
匹配單個字符 []——從中選擇一個字符匹配html
中間支持的類型:單詞字符([ae])、非單詞字符([!?,;@#$*])、字母範圍([A-Z])、數字範圍([0])java
eg.正則表達式[ae]ffect
可匹配字符串 affect,effect正則表達式
(此例中"[ae]"爲元字符,"ffect"爲字母文本)express
注意:
1.要在字符類中匹配連字符,那麼把連字符號做爲第一個字符列出便可。編程
2.能夠在單個正則表達式中包含多個字符類。數組
eg.[01][0-9]:[0-5][0-9][ap]m能夠用來匹配如12:59pm格式的全部時間編程語言
^——排除某些字符(在[]中表此意,還可表示字符串的開頭)函數
eg.正則表達式m[^a]t
可匹配字符串
不可匹配字符串 met,mit,m&t……mat工具
C#正則表達式語法2、
匹配特殊字符 可使用的特殊字符:
\t——匹配製表符 \r——匹配硬回車符 \f——匹配換頁符 \n——匹配換行符 描述表示字符類的元字符:
.——匹配任何除了\n之外的字符(或者在單行模式中的任何字符) \w——匹配任何單詞字符(任何字母或數字)
\W——匹配任何非單詞字符(除了字母和數字之外的任何字符) \s——匹配任何空白字符(包括空格、換行、製表符等)
\S——匹配任何非空白字符(除了空格、換行、製表符等的任何字符) \d——匹配任何數字字符(0~9的數字)
\D——匹配任何非數字字符(除了0~9之外的任何字符) 表示字符串中字符位置: ^——匹配字符串的開頭(或者多行模式下行的開頭)。
$——匹配字符串的結尾,或者是字符串結尾「\n」以前的最後一個字符,或者是多行模式中的行結尾。
\A——匹配字符串的開頭(忽略多行模式) \Z——匹配字符串的結尾或字符串結尾「\n」以前的最後一個字符(忽略多行模式)。
\z——匹配字符串的結尾。 \G——匹配當前搜索開始的位置。 \b——匹配單詞的邊界。 \B——匹配單詞的非邊界。
注意:
1.句點字符(.)特別有用。能夠用它來表示任何一個字符。
eg.正則表達式01.17.84
可匹配字符串 01/17/84,01-17-84,011784,01.17.84
2.可使用\b匹配單詞的邊界
eg.正則表達式
可匹配字符串 \blet\blet
不可匹配字符串letter,hamlet
3.\A和\z在確保字符串所包含的是某個表達式,而不是其餘內容時很用。
eg.要判斷Text控件是否包含單詞"sophia",而不含任何額外的字符、換行符或者空白。
\Asophia\z
4.句點字符(.)具備特殊的含義,若要表示字母字符自己的含義,在前面加一個反斜槓:\.
C#正則表達式語法3、
匹配二選一的字符序列
|——匹配二選一
eg.正則表達式col(o|ou)r
可匹配字符串 color,colour
注意:\b(bill|ted)和\bbill|ted是不一樣的。
後者還能夠匹配"malted"由於\b元字符只應用於"bill"。
C#正則表達式語法4、
用量詞匹配 *——匹配0次或屢次 +——匹配1次或屢次 ?——匹配0次或1次 {n}——剛好匹配n次 {n,}——至少匹配n次 {n,m}——至少匹配n次,
但很少於m次
eg.正則表達式brothers?
可匹配字符串 brother,brothers
eg.正則表達式\bp\d{3,5}
可匹配字符串 \b以p開頭,且後跟3~5個數字結尾
注意:也能夠把量詞與()一塊兒使用,以便把該量詞應用到整個字母序列。
eg.正則表達式(The)?schoolisbeautiful.
可匹配字符串 schoolisbeautiful,Theschoolisbeautiful.
C#正則表達式語法5、
識別正則表達式和貪婪 有些量詞是貪婪的(greedy).他們會盡量多的匹配字符。
如量詞*匹配0個或多個字符。假設要匹配字符串中任何HTML標籤。你可能會用以下正則表達式:
<.*>
現有字符串A<i>quantifier</i>canbe<big>greedy</big>
結果<.*>把<i>quantifier</i>canbe<big>greedy</big>都匹配上了。
要解決該問題,須要與量詞一塊兒使用一個特殊的非貪婪字符「?」,所以表達式變化以下:
<.*?>
這樣就能夠正確匹配<i>、</i>、<big>、</big>。
?能強制量詞儘量少地匹配字符,?還能夠用在如下幾個量詞中:
*?——非貪婪的量詞* +?——非貪婪的量詞+ ??——非貪婪的量詞? {n}?——非貪婪的量詞{n} {n,}?——非貪婪的量詞
{n,} {n,m}?——非貪婪的量詞{n,m}
C#正則表達式語法6、
捕獲和反向引用 捕獲組(capturegroup)就像是正則表達式中的變量。
捕獲組能夠捕獲正則表達式中的字符模式,而且由正則表達式後面的編號或名稱來引用改模式。
()——用來捕獲其中的字符串
\數字——用編號來引用
eg.
正則表達式 (\w)(\w)\2\1
可匹配字符串abba
注意:
1.反向引用用來匹配html標籤很是有效如<(\w+)></\1>能夠匹配<table></table>等相似格式的標籤。
2.默認狀況下,只要使用圓括號,就會捕獲圓括號內所包含的字符,可使用n選項來禁用這個默認行爲(在第7條裏會詳細介紹),
或者添加?:到圓括號中。eg.(?:sophia)或(?n:sophia)此時不會捕獲sophia。
(?<捕獲組名稱>)\k<捕獲組名稱>——用名稱來引用
eg.
正則表達式(?<sophia>\w)abc\k<sophia>
可匹配字符串 xabcx
注意:在替換模式中使用捕獲組的格式略有不一樣,要用$一、$2等來按數值引用捕獲,用${sophia}等名稱來按名稱引用捕獲組
C#正則表達式語法7、
設置正則表達式的選項
eg.
stringstr="<h4>sophia</h4>"
RegExobjRegEx=newRegEx("<h(d)>(.*?)</h1>");
Response.Write(objRegEx.Replace(str,"<fontsize=$1>$2</font>"));
i——所執行的匹配是不區分大小寫的(.net中的屬性爲IgnoreCase) m——指定多行模式(.net中的屬性爲Multiline)
n——只捕獲顯示命名或編號的組(.net中的屬性爲ExplicitCapture) c——編譯正則表達式,這樣會產生較快的執行速度,但啓動會變慢(.net中的屬性爲Compiled)
s——指定單行模式(.net中的屬性爲SingleLine) x——消除非轉義空白字符和註釋(.net中的屬性爲IgnorePatternWhitespace)
r——搜索從右到左進行(.net中的屬性爲RightToLeft) -——表示禁用。
eg.(?im-r:sophia)容許不區分大小寫匹配sophia,使用多行模式,但禁用了從右到左的匹配。
注意:
1.m會影響如何解析起始元字符(^)和結束元字符($)。
在默認狀況^和$只匹配整個字符串的開頭,即便字符串包含多行文本。若是啓用了m,那麼它們就能夠匹配每行文本的開頭和結尾。
2.s會影響如何解析句點元字符(.)。一般一個句點能匹配除了換行符之外的全部字符。但在單行模式下,句點也能匹配一個換行符。
正則表達式基礎知識
JScript | VBScript | 匹配 |
---|---|---|
/^\[ \t]*$/ | "^\[ \t]*$" | 匹配一個空白行。 |
/\d{2}-\d{5}/ | "\d{2}-\d{5}" | 驗證一個ID 號碼是否由一個2位數字,一個連字符以及一個5位數字組成。 |
/<(.*)>.*<\/\1>/ | "<(.*)>.*<\/\1>" | 匹配一個 HTML 標記。 |
字符 | 描述 |
---|---|
\ | 將下一個字符標記爲一個特殊字符、或一個原義字符、或一個 向後引用、或一個八進制轉義符。例如,'n' 匹配字符 "n"。'\n' 匹配一個換行符。序列 '\\' 匹配 "\" 而 "\(" 則匹配 "("。 |
^ | 匹配輸入字符串的開始位置。若是設置了 RegExp 對象的 Multiline 屬性,^ 也匹配 '\n' 或 '\r' 以後的位置。 |
$ | 匹配輸入字符串的結束位置。若是設置了RegExp 對象的 Multiline 屬性,$ 也匹配 '\n' 或 '\r' 以前的位置。 |
* | 匹配前面的子表達式零次或屢次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等價於{0,}。 |
+ | 匹配前面的子表達式一次或屢次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等價於 {1,}。 |
? | 匹配前面的子表達式零次或一次。例如,"do(es)?" 能夠匹配 "do" 或 "does" 中的"do" 。? 等價於 {0,1}。 |
{n} | n 是一個非負整數。匹配肯定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',可是能匹配 "food" 中的兩個 o。 |
{n,} | n 是一個非負整數。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的全部 o。'o{1,}' 等價於 'o+'。'o{0,}' 則等價於 'o*'。 |
{n,m} | m 和 n 均爲非負整數,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 將匹配 "fooooood" 中的前三個 o。'o{0,1}' 等價於 'o?'。請注意在逗號和兩個數之間不能有空格。 |
? | 當該字符緊跟在任何一個其餘限制符 (*, +, ?, {n}, {n,}, {n,m}) 後面時,匹配模式是非貪婪的。非貪婪模式儘量少的匹配所搜索的字符串,而默認的貪婪模式則儘量多的匹配所搜索的字符串。例如,對於字符串 "oooo",'o+?' 將匹配單個 "o",而 'o+' 將匹配全部 'o'。 |
. | 匹配除 "\n" 以外的任何單個字符。要匹配包括 '\n' 在內的任何字符,請使用象 '[.\n]' 的模式。 |
(pattern) | 匹配 pattern 並獲取這一匹配。所獲取的匹配能夠從產生的 Matches 集合獲得,在VBScript 中使用 SubMatches 集合,在JScript 中則使用 $0…$9 屬性。要匹配圓括號字符,請使用 '\(' 或 '\)'。 |
(?:pattern) | 匹配 pattern 但不獲取匹配結果,也就是說這是一個非獲取匹配,不進行存儲供之後使用。這在使用 "或" 字符 (|) 來組合一個模式的各個部分是頗有用。例如, 'industr(?:y|ies) 就是一個比 'industry|industries' 更簡略的表達式。 |
(?=pattern) | 正向預查,在任何匹配 pattern 的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不須要獲取供之後使用。例如,'Windows (?=95|98|NT|2000)' 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。預查不消耗字符,也就是說,在一個匹配發生後,在最後一次匹配以後當即開始下一次匹配的搜索,而不是從包含預查的字符以後開始。 |
(?!pattern) | 負向預查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不須要獲取供之後使用。例如'Windows (?!95|98|NT|2000)' 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。預查不消耗字符,也就是說,在一個匹配發生後,在最後一次匹配以後當即開始下一次匹配的搜索,而不是從包含預查的字符以後開始 |
x|y | 匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 則匹配 "zood" 或 "food"。 |
[xyz] | 字符集合。匹配所包含的任意一個字符。例如, '[abc]' 能夠匹配 "plain" 中的 'a'。 |
[^xyz] | 負值字符集合。匹配未包含的任意字符。例如, '[^abc]' 能夠匹配 "plain" 中的'p'。 |
[a-z] | 字符範圍。匹配指定範圍內的任意字符。例如,'[a-z]' 能夠匹配 'a' 到 'z' 範圍內的任意小寫字母字符。 |
[^a-z] | 負值字符範圍。匹配任何不在指定範圍內的任意字符。例如,'[^a-z]' 能夠匹配任何不在 'a' 到 'z' 範圍內的任意字符。 |
\b | 匹配一個單詞邊界,也就是指單詞和空格間的位置。例如, 'er\b' 能夠匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。 |
\B | 匹配非單詞邊界。'er\B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。 |
\cx | 匹配由 x 指明的控制字符。例如, \cM 匹配一個 Control-M 或回車符。x 的值必須爲 A-Z 或 a-z 之一。不然,將 c 視爲一個原義的 'c' 字符。 |
\d | 匹配一個數字字符。等價於 [0-9]。 |
\D | 匹配一個非數字字符。等價於 [^0-9]。 |
\f | 匹配一個換頁符。等價於 \x0c 和 \cL。 |
\n | 匹配一個換行符。等價於 \x0a 和 \cJ。 |
\r | 匹配一個回車符。等價於 \x0d 和 \cM。 |
\s | 匹配任何空白字符,包括空格、製表符、換頁符等等。等價於 [ \f\n\r\t\v]。 |
\S | 匹配任何非空白字符。等價於 [^ \f\n\r\t\v]。 |
\t | 匹配一個製表符。等價於 \x09 和 \cI。 |
\v | 匹配一個垂直製表符。等價於 \x0b 和 \cK。 |
\w | 匹配包括下劃線的任何單詞字符。等價於'[A-Za-z0-9_]'。 |
\W | 匹配任何非單詞字符。等價於 '[^A-Za-z0-9_]'。 |
\xn | 匹配 n,其中 n 爲十六進制轉義值。十六進制轉義值必須爲肯定的兩個數字長。例如,'\x41' 匹配 "A"。'\x041' 則等價於 '\x04' & "1"。正則表達式中可使用 ASCII 編碼。. |
\num | 匹配 num,其中 num 是一個正整數。對所獲取的匹配的引用。例如,'(.)\1' 匹配兩個連續的相同字符。 |
\n | 標識一個八進制轉義值或一個向後引用。若是 \n 以前至少 n 個獲取的子表達式,則 n 爲向後引用。不然,若是 n 爲八進制數字 (0-7),則 n 爲一個八進制轉義值。 |
\nm | 標識一個八進制轉義值或一個向後引用。若是 \nm 以前至少有 nm 個得到子表達式,則 nm 爲向後引用。若是 \nm 以前至少有 n 個獲取,則 n 爲一個後跟文字 m 的向後引用。若是前面的條件都不知足,若 n 和 m 均爲八進制數字 (0-7),則 \nm 將匹配八進制轉義值 nm。 |
\nml | 若是 n 爲八進制數字 (0-3),且 m 和 l 均爲八進制數字 (0-7),則匹配八進制轉義值 nml。 |
\un | 匹配 n,其中 n 是一個用四個十六進制數字表示的 Unicode 字符。例如, \u00A9 匹配版權符號 (©)。 |
下面看幾個例子:
"^The":表示全部以"The"開始的字符串("There","The cat"等);
"of despair$":表示因此以"of despair"結尾的字符串;
"^abc$":表示開始和結尾都是"abc"的字符串——呵呵,只有"abc"本身了;
"notice":表示任何包含"notice"的字符串。
'*','+'和'?'這三個符號,表示一個或一序列字符重複出現的次數。它們分別表示「沒有或
更多」,「一次或更多」還有「沒有或一次」。下面是幾個例子:
"ab*":表示一個字符串有一個a後面跟着零個或若干個b。("a", "ab", "abbb",……);
"ab+":表示一個字符串有一個a後面跟着至少一個b或者更多;
"ab?":表示一個字符串有一個a後面跟着零個或者一個b;
"a?b+$":表示在字符串的末尾有零個或一個a跟着一個或幾個b。
也可使用範圍,用大括號括起,用以表示重複次數的範圍。
"ab{2}":表示一個字符串有一個a跟着2個b("abb");
"ab{2,}":表示一個字符串有一個a跟着至少2個b;
"ab{3,5}":表示一個字符串有一個a跟着3到5個b。
請注意,你必須指定範圍的下限(如:"{0,2}"而不是"{,2}")。還有,你可能注意到了,'*','+'和
'?'至關於"{0,}","{1,}"和"{0,1}"。
還有一個'¦',表示「或」操做:
"hi¦hello":表示一個字符串裏有"hi"或者"hello";
"(b¦cd)ef":表示"bef"或"cdef";
"(a¦b)*c":表示一串"a""b"混合的字符串後面跟一個"c";
'.'能夠替代任何字符:
"a.[0-9]":表示一個字符串有一個"a"後面跟着一個任意字符和一個數字;
"^.{3}$":表示有任意三個字符的字符串(長度爲3個字符);
方括號表示某些字符容許在一個字符串中的某一特定位置出現:
"[ab]":表示一個字符串有一個"a"或"b"(至關於"a¦b");
"[a-d]":表示一個字符串包含小寫的'a'到'd'中的一個(至關於"a¦b¦c¦d"或者"[abcd]");
"^[a-zA-Z]":表示一個以字母開頭的字符串;
"[0-9]%":表示一個百分號前有一位的數字;
",[a-zA-Z0-9]$":表示一個字符串以一個逗號後面跟着一個字母或數字結束。
你也能夠在方括號裏用'^'表示不但願出現的字符,'^'應在方括號裏的第一位。(如:"%[^a-zA-Z]%"表
示兩個百分號中不該該出現字母)。
爲了逐字表達,必須在"^.$()¦*+?{\"這些字符前加上轉移字符'\'。
請注意在方括號中,不須要轉義字符。
執行的結果是:
First
Second
Third
看上去和String的Split方法同樣,但string的Split方法在由正則表達式而不是一組字符肯定的分隔符處拆分字符串。
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();
}
該事例運行結果是:Match1Group1='public'Capture0='public', Position=0Group2='string'Capture0='string', Position=7Match2Group1='testMatchObj'Capture0='testMatchObj', Position=14Group2='string'Capture0='string', Position=27Match3Group1='s'Capture0='s', Position=34Group2='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:0match POS:20