i 最常見的,大小寫忽略模式.
m (pcre_multiline) 多行模式.預設情況下,pcre將目標字串作為單一的一"行"字元所組成的(甚至其中包含有換行符也是如此)."行起始"元字元(^)僅僅匹配字串的起始,"行結束"元字元($)僅僅匹配字串的結束,或者最後乙個字元是換行符時其前面(除非設定了 d 修正符).這和 perl 是一樣的.當設定了此修正符"行起始"和"行結束"除了匹配整個字串開頭和結束外,還分別匹配其中的換行符的之後和之前.這和 perl 的 /m 修正符是等效的.如果目標字串中沒有"/n"字元或者模式中沒有^或$,則設定此修正符沒有任何效果.
s (pcre_dotall) 如果設定了此修正符,模式中的圓點元字元(.)匹配所有的字元,包括換行符.沒有此設定的話,則不包括換行符.這和 perl 的 /s 修正符是等效的.排除字元類例如 [^a] 總是匹配換行符的,無論是否設定了此修正符.
x (pcre_extended) 如果設定了此修正符,模式中的空白字元除了被轉義的或在字元類中的以外完全被忽略,在未轉義的字元類之外的#以及下乙個換行符之間的所有字元,包括兩頭,也都被忽略.這和perl 的/x 修正符是等效的,使得可以在複雜的模式中加入注釋。然而注意,這僅適用於資料字元。空白字元可能永遠不會出現於模式中的特殊字串行,例如引入條件子模式的序列 (?( 中間.
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 一樣,乙個反斜線後面跟乙個沒有特殊意義的字母被當成該字母本身。當前沒有其它特性受此修正符控制。即:貪婪模式,最 大限度匹配 如:/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 起可用.
示例稍後放出.
PHP正規表示式模式修正符
i pcre caseless 如果設定此修正符,模式中的字元將同時匹配大小寫字母。m pcre multiline 默 認情況下,pcre 將目標字串作為單一的一 行 字元所組成的 甚至其中包含有換行符也是如此 行起始 元字元 僅僅匹配字串的起始,行 結束 元字元 僅僅匹配字串的結束,或者最後乙個...
PHP正規表示式模式修正符
說明 下面列出了當前在 pcre 中可能使用的修正符。括號中是這些修正符的內部 pcre 名。i pcre caseless 如果設定此修正符,模式中的字元將同時匹配大小寫字母。m pcre multiline 默 認情況下,pcre 將目標字串作為單一的一 行 字元所組成的 甚至其中包含有換行符也...
正則匹配 模式修正符 小寫u的有關問題 php
正則匹配 模式修正符 小寫u的問題 php 最近看到一段 str 你好,世界dd preg match all us str,match echocount match 0 上網查了不少資料,但對於php正規表示式中的模式修正符u實在有些不明白,求解啊 分享到 更多 解決方案 u unicode的縮...