PHP 正則表達(dá)式后面接的/isU, /is, /s參數(shù)含義詳解
i 匹配大小寫(xiě)
s 模式中的圓點(diǎn)元字符(.)匹配所有的字符,包括換行符
x 模式中的空白字符除了被轉(zhuǎn)義的或在字符類中的'以外完全被忽略,在未轉(zhuǎn)義的字符類之外的 # 以及下一個(gè)換行符之間的所有字符,包括兩 頭,也都被忽略
A (PCRE_ANCHORED) 如果設(shè)定了此修正符,模式被強(qiáng)制為“anchored”,即強(qiáng)制僅從目標(biāo)字符串的開(kāi)頭開(kāi)始匹配即自動(dòng)在模式開(kāi)頭加上^。
D (PCRE_DOLLAR_ENDONLY) 如果設(shè)定了此修正符,模式中的美元元字符僅匹配目標(biāo)字符串的結(jié)尾。沒(méi)有此選項(xiàng)時(shí),如果最后一個(gè)字符是換行符的話,美元符號(hào)也會(huì)匹配此字符之前(但不會(huì)匹配任何其它換行符之前)。如果設(shè)定了 m 修正符則忽略此選項(xiàng)。Perl 中沒(méi)有與其等價(jià)的修正符。 S 當(dāng)一個(gè)模式將被使用若干次時(shí),為加速匹配起見(jiàn)值得先對(duì)其進(jìn)行分析。如果設(shè)定了此修正符則會(huì)進(jìn)行額外的分析。目前,分析一個(gè)模式僅對(duì)沒(méi)有單一固定起始字符的 non-anchored 模式有用。
U (PCRE_UNGREEDY) 本修正符反轉(zhuǎn)了匹配數(shù)量的值使其不是默認(rèn)的重復(fù),而變成在后面跟上“?”才變得重復(fù)。這和 Perl 不兼容。也可以通過(guò)在模式之中設(shè)定 (?U) 修正符來(lái)啟用此選項(xiàng)。
X (PCRE_EXTRA) 此 修正符啟用了一個(gè) PCRE 中與 Perl 不兼容的額外功能。模式中的任何反斜線后面跟上一個(gè)沒(méi)有特殊意義的字母導(dǎo)致一個(gè)錯(cuò)誤,從而保留此組合以備將 來(lái)擴(kuò)充。默認(rèn)情況下,和 Perl 一樣,一個(gè)反斜線后面跟一個(gè)沒(méi)有特殊意義的字母被當(dāng)成該字母本身。當(dāng)前沒(méi)有其它特性受此修正符控制。即:貪婪模式,最 大限度匹配 如:/a[w]+?e/U匹配abceadeddd中的abceade而不是abce,如果不加U修正,則匹配abce u (PCRE_UTF8) 此修正符啟用了一個(gè) PCRE 中與 Perl 不兼容的額外功能。模式字符串被當(dāng)成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。
【PHP 正則表達(dá)式后面接的/isU, /is, /s參數(shù)含義詳解】相關(guān)文章: