正則表達

2020-08-10 11:35:37

元字元 描述
\ 將下一個字元標記符、或一個向後參照、或一個八進制跳脫符。例如,「\n」匹配\n。「\n」匹配換行符。序列「\」匹配「\」而「(」則匹配「(」。即相當於多種程式語言中都有的「跳脫字元」的概念。
^ 匹配輸入字行首。如果設定了RegExp物件的Multiline屬性,^也匹配「\n」或「\r」之後的位置。
$ 匹配輸入行尾。如果設定了RegExp物件的Multiline屬性,$也匹配「\n」或「\r」之前的位置。

  • 匹配前面的子表達式任意次。例如,zo*能匹配「z」,也能匹配「zo」以及「zoo」。*等價於{0,}。
  • 匹配前面的子表達式一次或多次(大於等於1次)。例如,「zo+」能匹配「zo」以及「zoo」,但不能匹配「z」。+等價於{1,}。
    ? 匹配前面的子表達式零次或一次。例如,「do(es)?」可以匹配「do」或「does」。?等價於{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爲一組。「o{0,1}」等價於「o?」。請注意在逗號和兩個數之間不能有空格。
    ? 當該字元緊跟在任何一個其他限制符(*,+,?,{n},{n,},{n,m})後面時,匹配模式是非貪婪的。非貪婪模式儘可能少地匹配所搜尋的字串,而預設的貪婪模式則儘可能多地匹配所搜尋的字串。例如,對於字串「oooo」,「o+」將盡可能多地匹配「o」,得到結果[「oooo」],而「o+?」將盡可能少地匹配「o」,得到結果 [‘o’, ‘o’, ‘o’, ‘o’]
    .點 匹配除「\n」和"\r"之外的任何單個字元。要匹配包括「\n」和"\r"在內的任何字元,請使用像「[\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」。
    *python的正則表達式沒有完全按照正則表達式規範實現,所以一些高階特性建議使用其他語言如java、scala等
    (?<!patte_n) 非獲取匹配,反向否定預查,與正向否定預查類似,只是方向相反。例如「(?<!95|98|NT|2000)Windows」能匹配「3.1Windows」中的「Windows」,但不能匹配「2000Windows」中的「Windows」。
    python的正則表達式沒有完全按照正則表達式規範實現,所以一些高階特性建議使用其他語言如java、scala等
    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 匹配一個單詞的邊界,也就是指單詞和空格間的位置(即正則表達式的「匹配」有兩種概念,一種是匹配字元,一種是匹配位置,這裏的\b就是匹配位置的)。例如,「er\b」可以匹配「never」中的「er」,但不能匹配「verb」中的「er」;「\b1_」可以匹配「1_23」中的「1_」,但不能匹配「21_3」中的「1_」。
    \B 匹配非單詞邊界。「er\B」能匹配「verb」中的「er」,但不能匹配「never」中的「er」。
    \cx 匹配由x指明的控制字元。例如,\cM匹配一個Control-M或回車符。x的值必須爲A-Z或a-z之一。否則,將c視爲一個原義的「c」字元。
    \d 匹配一個數字字元。等價於[0-9]。grep 要加上-P,perl正則支援
    \D 匹配一個非數位字元。等價於[^0-9]。grep要加上-P,perl正則支援
    \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_]」,這裏的"單詞"字元使用Unicode字元集。
    \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匹配版權符號(©)。
    \p{P} 小寫 p 是 property 的意思,表示 Unicode 屬性,用於 Unicode 正表達式的字首。中括號內的「P」表示Unicode 字元集七個字元屬性之一:標點字元。
    其他六個屬性:
    L:字母;
    M:標記符號(一般不會單獨出現);
    Z:分隔符(比如空格、換行等);
    S:符號(比如數學符號、貨幣符號等);
    N:數位(比如阿拉伯數位、羅馬數位等);
    C:其他字元。
    注:此語法部分語言不支援,例:javascript。
    <
    > 匹配詞(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."。注意:這個元字元不是所有的軟體都支援的。