模式修正符

模式修正符

模式修正符 — 解說正則表達式模式中使用的修正符

說明

下面列出瞭當前在 PCRE 中可能使用的修正符。括號中是這些修正符的內部 PCRE 名。 

 

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 中不可用。

例子:把html的所有標簽修改成大寫

preg_replace ("/(<\/?)(\w+)([^>]*>)/e","'\\1'.strtoupper('\\2').'\\3'",$html_body);

不過有人反映這麼處理要比preg_replace_callback方式慢20倍

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 起可用。

例子:

preg_match('/[\x{2460}-\x{2468}]/u', $str);  匹配 內碼漢字

發佈留言