在學習PHPRegex修飾符之前先來理解下貪婪模式,前面在元字元中提到過"?"還有一個重要的作用,即"貪婪模式",什麼是"貪婪模式"呢?
PHPRegex貪婪模式:
比如我們要匹配以字母"a"開頭字母"b"結尾的字串,但是需要匹配的字串在"a"後面含有很多個"b",比如"a bbbbbbbbbbbbbbbbb",那Regex是會匹配第一個"b"還是最後一個"b"呢?如果你使用了貪婪模式,那麼會匹配到最後一個"b",反之只是匹配到第一個"b"。
PHPRegex貪婪模式使用執行個體:
/a.+?b/
/a.+b/U
對比不使用貪婪模式的執行個體如下:
/a.+b/
上面使用了一個修飾符U,詳見關於修飾符的介紹。
PHPRegex /i, /is, /s, /isU等 都是些什麼東西呢?
i 不區分大小寫
s 模式中的圓點元字元(.)匹配所有的字元,包括分行符號
x 模式中的空白字元除了被轉義的或在字元類中的以外完全被忽略,在未轉義的字元類之外的 # 以及下一個分行符號之間的所有字元,包括兩 頭,也都被忽略
A (PCRE_ANCHORED) 如果設定了此修正符,模式被強製為“anchored”,即強制僅從目標字串的開頭開始匹配即自動在模式開頭加上^。
D (PCRE_DOLLAR_ENDONLY) 如果設定了此修正符,模式中的美元元字元僅匹配目標字串的結尾。沒有此選項時,如果最後一個字元是分行符號的話,貨幣符號也會匹配此字元之前(但不會匹配 任何其它分行符號之前)。如果設定了 m 修正符則忽略此選項。Perl 中沒有與其等價的修正符。 S 當一個模式將被使用若干次時,為加速匹配起見值得先對其進行分析。如果設定了此修正符則會進行額外的分析。目前,分析一個模式僅對沒有單一固定起始字元的 non-anchored 模式有用。
U (PCRE_UNGREEDY) 本修正符反轉了匹配數量的值使其不是預設的重複,而變成在後面跟上“?”才變得重複。這和 Perl 不相容。也可以通過在模式之中設定 (?U) 修正符來啟用此選項。
X (PCRE_EXTRA) 此 修正符啟用了一個 PCRE 中與 Perl 不相容的額外功能。模式中的任何反斜線後面跟上一個沒有特殊意義的字母導致一個錯誤,從而保留此組合以備將 來擴充。預設情況下,和 Perl 一樣,一個反斜線後面跟一個沒有特殊意義的字母被當成該字母本身。當前沒有其它特性受此修正符控制。即:貪婪模式,最 大限度匹配 如:/a[\w]+?e/U匹配abceadeddd中的abceade而不是abce,如果不加U修正,則匹配abce u (PCRE_UTF8) 此修正符啟用了一個 PCRE 中與 Perl 不相容的額外功能。模式字串被當成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。
PHPRegex修飾符的理解:
在PHPRegex裡面的修飾符可以改變正則的很多特性,使得Regex更加適合你的需要(注意:修飾符對於大小寫是敏感的,這意味著"e"並不等於"E")。
PHPRegex修飾符的種類及介紹:
◆i :如果在修飾符中加上"i",則正則將會取消大小寫敏感性,即"a"和"A" 是一樣的。
◆m:預設的正則開始"^"和結束"$"只是對於正則字串如果在修飾符中加上"m",那麼開始和結束將會指字串的每一行:每一行的開頭就是"^",結尾就是"$"。
◆s:如果在修飾符中加入"s",那麼預設的"."代表除了分行符號以外的任何字元將會變成任一字元,也就是包括分行符號!
◆x:如果加上該修飾符,運算式中的空白字元將會被忽略,除非它已經被轉義。
◆e:本修飾符僅僅對於replacement有用,代表在replacement中作為PHP代碼。
◆A:如果使用這個修飾符,那麼運算式必須是匹配的字串中的開頭部分。比如說"/a/A"匹配"abcd"。
◆E:與"m"相反,如果使用這個修飾符,那麼"$"將匹配絕對字串的結尾,而不是分行符號前面,預設就開啟了這個模式。
◆U:和問號的作用差不多,用於設定"貪婪模式"。
PHPRegex修飾符的相關內容就向你介紹到這裡,希望對你瞭解和掌握PHPRegex修飾符有所協助。