新聞資訊

PHP正則表達式 /i, /is, /s, /isU等

PHP正則表達式 /i, /is, /s, /isU等 都是(shì)些什麽東西呢?

i 匹配大小寫

s 模式中的圓點元字符(.)匹配所有的字符,包括換行符

x 模式中的空白字符除了被轉義的或在字符類中的以外完全被忽略,在未轉義的字符類之外的 # 以及下一個換行符之間的所有字符,包括兩 頭,也都被忽略

A (PCRE_ANCHORED) 如果設定了此修正符,模式被強制爲“anchored”,即強制僅從目标字符串的開頭開始匹配即自動在模式開頭加上^。

D (PCRE_DOLLAR_ENDONLY) 如果設定了此修正符,模式中的美元元字符僅匹配目标字符串的結尾。沒有此選項時,如果最後一個字符是(shì)換行符的話(huà),美元符号也會匹配此字符之前(但(dàn)不會匹配 任何其它換行符之前)。如果設定了 m 修正符則忽略此選項。Perl 中沒有與其等價的修正符。 合肥網站建設公司

S 當一個模式将被使用若幹次時,爲加速匹配起見(jiàn)值得先對其進行分析。如果設定了此修正符則會進行額外的分析。目前,分析一個模式僅對沒有單一固定起始字符的 non-anchored 模式有用。 

U (PCRE_UNGREEDY) 本修正符反轉了匹配數量的值使其不是(shì)默認的重複,而變成在後面跟上“?”才變得重複。這和 Perl 不兼容。也可以通過在模式之中設定 (?U) 修正符來啓用此選項。

X (PCRE_EXTRA) 此 修正符啓用了一個 PCRE 中與 Perl 不兼容的額外功能。模式中的任何反斜線(xiàn)後面跟上一個沒有特殊意義的字母導緻一個錯誤,從而保留此組合以備将 來擴充。默認情況下,和 Perl 一樣,一個反斜線(xiàn)後面跟一個沒有特殊意義的字母被當成該字母本身。當前沒有其它特性受此修正符控制。即:貪婪模式,最 大限度匹配 如:/a[\w]+?e/U匹配abceadeddd中的abceade而不是(shì)abce,如果不加U修正,則匹配abce  u (PCRE_UTF8) 此修正符啓用了一個 PCRE 中與 Perl 不兼容的額外功能。模式字符串被當成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。