正则表达式-元字符
.:匹配任何單個字符。例如正則表達式“b.g”能匹配如下字符串:“big”、“bug”、“b g”,但是不匹配“buug”,“b..g”可以匹配“buug”。?
[] :匹配括號中的任何一個字符。例如正則表達式“b[aui]g”匹配bug、big和bag,但是不匹配beg、baug。可以在括號中使用連字符“-”來指定字符的區間來簡化表示,例如正則表達式[0-9]可以匹配任何數字字符,這樣正則表達式“a[0-9]c”等價于“a[0123456789]c”就可以匹配“a0c”、“a1c”、“a2c”等字符串;還可以制定多個區間,例如“[A-Za-z]”可以匹配任何大小寫字母,“[A-Za-z0-9]”可以匹配任何的大小寫字母或者數字。
( ) :將 () 之間括起來的表達式定義為“組”(group),并且將匹配這個表達式的字符保存到一個臨時區域,這個元字符在字符串提取的時候非常有用。把一些字符表示為一個整體。改變優先級、提取。
| :將兩個匹配條件進行邏輯“或”運算。'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 則匹配 "zood" 或 "food"。
*:匹配0至多個在它之前的子表達式,和通配符*沒關系。例如正則表達式“zo*”能匹配 “z” 、“zo”以及 “zoo”;因此“.*”意味著能夠匹配任意字符串。"z(b|c)*"→zb、zbc、zcb、zccc、zbbbccc。"z(ab)*"能匹配z、zab、zabab。
+ :匹配前面的子表達式一次或多次,和*對比(0到多次)。例如正則表達式9+匹配9、99、999等。 “zo+”能匹配 “zo”以及 “zoo” ,不能匹配"z"。
? :匹配前面的子表達式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 。
{n} :匹配確定的 n 次。"zo{2}"→z00。例如,“e{2}” 不能匹配“bed”中的“e”,但是能匹配“seed”中的兩個“e”。
{n,} :至少匹配n次。例如,“e{2,}”不能匹配“bed”中的“e”,但能匹配 “seeeeeeeed”中的所有“e”。
{n,m} :最少匹配 n 次且最多匹配 m 次。“e{1,3}”將匹配“seeeeeeeed”中的前三個“e”。
^ :匹配一行的開始。例如正則表達式“^AJAX”能夠匹配字符串“AJAX 我會用”的開始,但是不能匹配“我會用AJAX”。
^另外一種意思:非!(暫時不用理解)
$ :匹配行結束符。例如正則表達式“曾哥$” 能夠匹配字符串“我愛曾哥”的末尾,但是不能匹配字符串“曾哥純爺們兒”
注意這些簡寫表達式是不考慮轉義符的,這里的\就表示字符\,而不是C#字符串級別的\,在C#代碼中需要使用@或者\雙重轉義。"\\d"或者@"\d"
\d:代表一個數字,等同于[0-9]
\D:代表非數字,等同于[^0-9]
\s:代表換行符、Tab制表符等空白字符
\S:代表非空白字符
\w:匹配字母或數字或下劃線或漢字。能組成單詞
\W:非\w ,等同于[^\w]
d:digital;s:space、w:word。大寫就是“非”
轉載于:https://www.cnblogs.com/flykarry/archive/2013/01/21/2870490.html
總結
- 上一篇: [转]使用debugger调试JavaS
- 下一篇: (转)如何压缩SQL Server 20