天天看點

JS 正規表達式

符号

正規表達式由一組普通字元和元字元組成。

普通字元包括數字和大小寫的字母。

元字元 描述

  \ 将下一個字元标記為一個特殊字元、或一個原義字元、或一個向後引用、或一個八進制轉義符。例如,“\\n”比對\n。“\n”比對換行符。序列“\\”比對“\”而“\(”則比對“(”。

  ^ 比對輸入字元串的開始位置。如果設定了RegExp對象的Multiline屬性,^也比對“\n”或“\r”之後的位置。

  $ 比對輸入字元串的結束位置。如果設定了RegExp對象的Multiline屬性,$也比對“\n”或“\r”之前的位置。

  * 比對前面的子表達式零次或多次(大于等于0次)。例如,zo*能比對“z”,“zo”以及“zoo”。*等價于{0,}。

  + 比對前面的子表達式一次或多次(大于等于1次)。例如,“zo+”能比對“zo”以及“zoo”,但不能比對“z”。+等價于{1,}。

  ? 比對前面的子表達式零次或一次。例如,“do(es)?”可以比對“does”或“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”。

  .點 比對除“\r\n”之外的任何單個字元。要比對包括“\r\n”在内的任何字元,請使用像“[\s\S]”的模式。

  (pattern) 比對pattern并擷取這一比對。所擷取的比對可以從産生的Matches集合得到,在VBScript中使用SubMatches集合,在JScript中則使用$0…$9屬性。要比對圓括号字元,請使用“\(”或“\)”。

  (?:pattern) 比對pattern但不擷取比對結果,也就是說這是一個非擷取比對,不進行存儲供以後使用。這在使用或字元“(|)”來組合一個模式的各個部分是很有用。例如“industr(?:y|ies)”就是一個比“industry|industries”更簡略的表達式。

  (?=pattern) 正向肯定預查,在任何比對pattern的字元串開始處比對查找字元串。這是一個非擷取比對,也就是說,該比對不需要擷取供以後使用。例如,“Windows(?=95|98|NT|2000)”能比對“Windows2000”中的“Windows”,但不能比對“Windows3.1”中的“Windows”。預查不消耗字元,也就是說,在一個比對發生後,在最後一次比對之後立即開始下一次比對的搜尋,而不是從包含預查的字元之後開始。

  (?!pattern) 正向否定預查,在任何不比對pattern的字元串開始處比對查找字元串。這是一個非擷取比對,也就是說,該比對不需要擷取供以後使用。例如“Windows(?!95|98|NT|2000)”能比對“Windows3.1”中的“Windows”,但不能比對“Windows2000”中的“Windows”。

  (?<=pattern) 反向肯定預查,與正向肯定預查類似,隻是方向相反。例如,“(?<=95|98|NT|2000)Windows”能比對“2000Windows”中的“Windows”,但不能比對“3.1Windows”中的“Windows”。

  (?<!pattern) 反向否定預查,與正向否定預查類似,隻是方向相反。例如“(?<!95|98|NT|2000)Windows”能比對“3.1Windows”中的“Windows”,但不能比對“2000Windows”中的“Windows”。

  x|y 比對x或y。例如,“z|food”能比對“z”或“food”。“(z|f)ood”則比對“zood”或“food”。

  [xyz] 字元集合。比對所包含的任意一個字元。例如,“[abc]”可以比對“plain”中的“a”。

  [^xyz] 負值字元集合。比對未包含的任意字元。例如,“[^abc]”可以比對“plain”中的“plin”。

  [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-7),且m和l均為八進制數字(0-7),則比對八進制轉義值nml。

  \un 比對n,其中n是一個用四個十六進制數字表示的Unicode字元。例如,\u00A9比對版權符号(&copy;)。

  \< \> 比對詞(word)的開始(\<)和結束(\>)。例如正規表達式\<the\>能夠比對字元串"for the wise"中的"the",但是不能比對字元串"otherwise"中的"the"。注意:這個元字元不是所有的軟體都支援的。

  \( \) 将 \( 和 \) 之間的表達式定義為“組”(group),并且将比對這個表達式的字元儲存到一個臨時區域(一個正規表達式中最多可以儲存9個),它們可以用 \1 到\9 的符号來引用。

  | 将兩個比對條件進行邏輯“或”(Or)運算。例如正規表達式(him|her) 比對"it belongs to him"和"it belongs to her",但是不能比對"it belongs to them."。注意:這個元字元不是所有的軟體都支援的。

  + 比對1或多個正好在它之前的那個字元。例如正規表達式9+比對9、99、999等。注意:這個元字元不是所有的軟體都支援的。

  ? 比對0或1個正好在它之前的那個字元。注意:這個元字元不是所有的軟體都支援的。

  {i} {i,j} 比對指定數目的字元,這些字元是在它之前的表達式定義的。例如正規表達式A[0-9]{3} 能夠比對字元"A"後面跟着正好3個數字字元的串,例如A123、A348等,但是不比對A1234。而正規表達式[0-9]  {4,6} 比對連續的任意4個、5個或者6個數字

最簡單的元字元是點,它能夠比對任何單個字元(注意不包括換行符)。

例如:

1. 将所有方法foo(a,b,c)的執行個體改為foo(b,a,c)。這裡a、b和c可以是任何提供給方法foo()的參數。

[^,] 除了逗号之外的任何字元

[^,]* 0或者多個非逗号字元

\([^,]*\) 将這些非逗号字元标記為\1,這樣可以在之後的替換模式表達式中引用它, \( \)定義組。

\([^,]*\), 我們必須找到0或者多個非逗号字元後面跟着一個逗号,并且非逗号字元那部分要标記出來以備後用。

這個表達式我們已經分析到了:foo(\([^,]*\),這一段可以簡單的翻譯為“當你找到foo(就把其後直到第一個逗号之前的部分标記為\1”。然後我們使用同樣的辦法标記第二個參數為\2。對第三個參數的标記方法也是一樣,隻是我們要搜尋所有的字元直到右括号。我們并沒有必要去搜尋第三個參數,因為我們不需要調整它的位置,但是這樣的模式能夠保證我們隻去替換那些有三個參數的foo()方法調用,在foo()是一個重載(overloading)方法時這種明确的模式往往是比較保險的。然後,在替換部分,我們找到foo()的對應執行個體,然後利用标記好的部分進行替換,是把第一和第二個參數交換位置。

foo(\([^,]* \),\([^,]* \),\([^]* \) )

foo(\2,\1,\3)

速記了解技巧

. [] ^ $ 四個字元是所有語言都支援的正規表達式,是以這個四個是基礎的正規表達式。

等價:

?等價于比對長度{0,1}

*等價于比對長度{0,}

+等價于比對長度{1,}

\d等價于[0-9]

\w等價于[A-Za-z_0-9]。

常用運算符與表達式:

  ^ 開始

  () 域段

  [] 包含,預設是一個字元長度

  [^] 不包含,預設是一個字元長度

  {n,m} 比對長度

  . 任何單個字元(\. 字元點)

  | 或

  \ 轉義

  $ 結尾

  [A-Z] 26個大寫字母

  [a-z] 26個小寫字母

  [0-9] 0至9數字

  [A-Za-z0-9] 26個大寫字母、26個小寫字母和0至9數字

  , 分割

 分割文法:

  [A,H,T,W] 包含A或H或T或W字母

  [0,3,6,8] 包含0或3或6或8數字

文法與釋義:

  基礎文法 "^([]{})([]{})([]{})$"

  正則字元串 = "開始([包含内容]{長度})([包含内容]{長度})([包含内容]{長度})結束"

執行個體:

1.字元串: tel:086-0666-88810009999

正則比對:^tel:\d{1,3}-[0]\d{3}-\d{11}$

2.替換指定内容到行尾

原始文本:12313 abc weouorwe

替換為:将abc及後面的字元統一替換為abc defg

str.replace(/abc.*/,"abc defg")  

3.數字替換

原始文本:asdadas123asdasdas456asdasdasd789asdasd

替換為:asdadas[123]asdasdas[456]asdasdasd[789]asdasd

str.replace(/\d+/g, function(word){return '['+word +']'})

4. 删除每一行行尾的指定字元

原始文本:12345 1265345

删除末尾的345

str.replace(/345$/,"")

5. 驗證電話号碼:^\d{3,4}-\d{7,8}$

格式: xxx/xxxx-xxxxxxx/xxxxxxxx

6. 隻能輸入數字:^\d*$

7. 隻能輸入n位的數字:^\d{n}$

8. 隻能輸入至少n位的數字:^\d{n,}$

10. 隻能輸入m~n位的數字:^\d{m,n}$

11. 隻能輸入有兩位小數的正實數:^[0-9]+\.[0-9]{2}$

12. 擷取日期正規表達式:^\d{4}[年|\-|\.]+\d{1,2}[月|\-|\.]+\d{1,2}[日]?$

格式:2014-06-12 2014年6月12日 2014.9.12

來源:http://baike.baidu.com/view/94238.htm?fr=aladdin

測試工具:http://tool.oschina.net/regex

js