下面列出了當前可用的 PCRE 修飾符。括號中提到的名字是 PCRE 內部這些修飾符的名稱。 模式修飾符中的空格,換行符會被忽略,其餘字符會致使錯誤。php
- i ( PCRE_CASELESS)
- 若是設置了這個修飾符,模式中的字母會進行大小寫不敏感匹配。
- m ( PCRE_MULTILINE)
- 默認狀況下,PCRE 認爲目標字符串是由單行字符組成的(然而實際上它可能會包含多行), "行首"元字符 (^) 僅匹配字符串的開始位置, 而"行末"元字符 ($) 僅匹配字符串末尾, 或者最後的換行符(除非設置了 D 修飾符)。這個行爲和 perl 相同。 當這個修飾符設置以後,「行首」和「行末」就會匹配目標字符串中任意換行符以前或以後,另外, 還分別匹配目標字符串的最開始和最末尾位置。這等同於 perl 的 /m 修飾符。若是目標字符串 中沒有 "\n" 字符,或者模式中沒有出現 ^ 或 $,設置這個修飾符不產生任何影響。
- s ( PCRE_DOTALL)
- 若是設置了這個修飾符,模式中的點號元字符匹配全部字符,包含換行符。若是沒有這個 修飾符,點號不匹配換行符。這個修飾符等同於 perl 中的/s修飾符。 一個取反字符類好比 [^a] 老是匹配換行符,而不依賴於這個修飾符的設置。
- x ( PCRE_EXTENDED)
- 若是設置了這個修飾符,模式中的沒有通過轉義的或不在字符類中的空白數據字符總會被忽略, 而且位於一個未轉義的字符類外部的#字符和下一個換行符之間的字符也被忽略。 這個修飾符 等同於 perl 中的 /x 修飾符,使被編譯模式中能夠包含註釋。 注意:這僅用於數據字符。 空白字符 仍是不能在模式的特殊字符序列中出現,好比序列 (?( 引入了一個條件子組(譯註: 這種語法定義的 特殊字符序列中若是出現空白字符會致使編譯錯誤。 好比(?(就會致使錯誤)。
- A ( PCRE_ANCHORED)
- 若是設置了這個修飾符,模式被強制爲"錨定"模式,也就是說約束匹配使其僅從 目標字符串的開始位置搜索。這個效果一樣可使用適當的模式構造出來,而且 這也是 perl 種實現這種模式的惟一途徑。
- D ( PCRE_DOLLAR_ENDONLY)
- 若是這個修飾符被設置,模式中的元字符美圓符號僅僅匹配目標字符串的末尾。若是這個修飾符 沒有設置,當字符串以一個換行符結尾時, 美圓符號還會匹配該換行符(但不會匹配以前的任何換行符)。 若是設置了修飾符m,這個修飾符被忽略. 在 perl 中沒有與此修飾符等同的修飾符。
- S
- 當一個模式須要屢次使用的時候,爲了獲得匹配速度的提高,值得花費一些時間 對其進行一些額外的分析。若是設置了這個修飾符,這個額外的分析就會執行。當前, 這種對一個模式的分析僅僅適用於非錨定模式的匹配(即沒有單獨的固定開始字符)。
- U ( PCRE_UNGREEDY)
- 這個修飾符逆轉了量詞的"貪婪"模式。 使量詞默認爲非貪婪的,經過量詞後緊跟? 的方式可使其成爲貪婪的。這和 perl 是不兼容的。 它一樣可使用 模式內修飾符設置 (?U)進行設置, 或者在量詞後以問號標記其非貪婪(好比.*?)。
- X ( PCRE_EXTRA)
- 這個修飾符打開了 PCRE 與 perl 不兼容的附件功能。模式中的任意反斜線後就 ingen 一個 沒有特殊含義的字符都會致使一個錯誤,以此保留這些字符以保證向後兼容性。 默認狀況下,在 perl 中,反斜線緊跟一個沒有特殊含義的字符被認爲是該字符的原文。 當前沒有其餘特性由這個修飾符控制。
- J ( PCRE_INFO_JCHANGED)
- 內部選項設置(?J)修改本地的PCRE_DUPNAMES選項。容許子組重名, (譯註:只能經過內部選項設置,外部的 /J 設置會產生錯誤。)
- u ( PCRE_UTF8)
- 此修正符打開一個與 perl 不兼容的附加功能。 模式字符串被認爲是utf-8的. 這個修飾符 從 unix 版php 4.1.0 或更高,win32版 php 4.2.3 開始可用。 php 4.3.5 開始檢查模式的 utf-8 合法性。