i (pcre_caseless)
如果設定此修正符,模式中的字元將同時匹配大小寫字母。
m(pcre_multiline)
預設情況下,pcre 將目標字串作為單一的一「行」字元所組成的(甚至其中包含有換行符也是如此)。「行起始」元字元(^)僅僅匹配字串的起始,「行結束」元字元($)僅 僅匹配字串的結束,或者最後乙個字元是換行符時其前面(除非設定了 d 修正符)。這和 perl 是一樣的。
當設定了此修正符,「行起始」和「行結束」除了匹配整個字串開頭和結束外,還分別匹配其中的換行符的之後和之前。這和 perl 的 /m 修正符是等效的。如果目標字串中沒有「/n」字元或者模式中沒有 ^ 或 $,則設定此修正符沒有任何效果。
s(pcre_dotall)
如果設定了此修正符,模式中的圓點元字元(.)匹配所有的字元,包括換行符。沒有此設定的話,則不包括換行符。這和 perl 的 /s 修正符是等效的。排除字元類例如 [^a] 總是匹配換行符的,無論是否設定了此修正符。
x(pcre_extended)
如果設定了此修正符,模式中的空白字元除了被轉義的或在字元類中的以外完全被忽略,在未轉義的字元類之外的 # 以及下乙個換行符之間的所有字元,包括兩頭,也都被忽略。這和 perl 的 /x 修正符是等效的,使得可以在複雜的模式中加入注釋。然而注意,這僅適用於資料字元。空白字元可能永遠不會出現於模式中的特殊字串行,例如引入條件子模式 的序列 (?( 中間。
e如果設定了此修正符,preg_replace() 在替換字串中對逆向引用作正常的替換,將其作為 php **求值,並用其結果來替換所搜尋的字串。
只有 preg_replace() 使用此修正符,其它 pcre 函式將忽略之。
注: 本修正符在 php3 中不可用。
a(pcre_anchored)
如果設定了此修正符,模式被強制為「anchored」,即強制僅從目標字串的開頭開始匹配。此效果也可以通過適當的模式本身來實現(在 perl 中實現的唯一方法)。
d(pcre_dollar_endonly)
如果設定了此修正符,模式中的美元元字元僅匹配目標字串的結尾。沒有此選項時,如果最後乙個字元是換行符的話,美元符號也會匹配此字元之前(但不會匹配任何其它換行符之前)。如果設定了 m 修正符則忽略此選項。perl 中沒有與其等價的修正符。
s當乙個模式將被使用若干次時,為加速匹配起見值得先對其進行分析。如果設定了此修正符則會進行額外的分析。目前,分析乙個模式僅對沒有單一固定起始字元的 non-anchored 模式有用。
u(pcre_ungreedy)
本修正符反轉了匹配數量的值使其不是預設的重複,而變成在後面跟上「?」才變得重複。這和 perl 不相容。也可以通過在模式之中設定 (?u) 修正符或者在數量符之後跟乙個問號(如 .*?)來啟用此選項。
x(pcre_extra)
此修正符啟用了乙個 pcre 中與 perl 不相容的額外功能。模式中的任何反斜線後面跟上乙個沒有特殊意義的字母導致乙個錯誤,從而保留此組合以備將來擴充。預設情況下,和 perl 一樣,乙個反斜線後面跟乙個沒有特殊意義的字母被當成該字母本身。當前沒有其它特性受此修正符控制。
u(pcre_utf8)
此修正符啟用了乙個 pcre 中與 perl 不相容的額外功能。模式字串被當成 utf-8。本修正符在 unix 下自 php 4.1.0 起可用,在 win32 下自 php 4.2.3 起可用。自 php 4.3.5 起開始檢查模式的 utf-8 合法性。
php正規表示式詳解,PHP正規表示式使用詳解
操作符 描述 轉義符 圓括號和方括號 限定符 anymetacharacter 位置和順序 或 操作 全部符號解釋 字元 描述 將下乙個字元標記為乙個特殊字元 或乙個原義字元 或乙個 向後引用 或乙個八進位制轉義符。例如,n 匹配字元 n n 匹配乙個換行符。序列 匹配 而 則匹配 匹配輸入字串的開...
PHP正規表示式模式後面 U, s 引數
u pcre ungreedy 這個修飾符逆轉了量詞的 貪婪 模式。使量詞預設為非貪婪的,通過量詞後緊跟?的方式可以使其成為貪婪的。這和 perl 是不相容的。它同樣可以使用模式內修飾符設定 u 進行設定,或者在量詞後以問號標記其非貪婪 比如.例 1 str aabcaabab regx a.b u...
PHP正規表示式使用詳解
操作符 描述 轉義符 圓括號和方括號 限定符 anymetacharacter 位置和順序 或 操作 全部符號解釋 字元 描述 將下乙個字元標記為乙個特殊字元 或乙個原義字元 或乙個 向後引用 或乙個八進位制轉義符。例如,n 匹配字元 n n 匹配乙個換行符。序列 匹配 而 則匹配 匹配輸入字串的開...