PHP正則表達式 /i, /is, /s, /isU等
PHP正則表達式 /i, /is, /s, /isU等 都是(shì)些什麽東西呢?
i 匹配大(dà)小寫
s 模式中的(de)圓點元字符(.)匹配所有的(de)字符,包括換行符
x 模式中的(de)空白字符除了(le/liǎo)被轉義的(de)或在(zài)字符類中的(de)以(yǐ)外完全被忽略,在(zài)未轉義的(de)字符類之(zhī)外的(de) # 以(yǐ)及下一(yī / yì /yí)個(gè)換行符之(zhī)間的(de)所有字符,包括兩 頭,也(yě)都被忽略
A (PCRE_ANCHORED) 如果設定了(le/liǎo)此修正符,模式被強制爲(wéi / wèi)“anchored”,即強制僅從目标字符串的(de)開頭開始匹配即自動在(zài)模式開頭加上(shàng)^。
D (PCRE_DOLLAR_ENDONLY) 如果設定了(le/liǎo)此修正符,模式中的(de)美元元字符僅匹配目标字符串的(de)結尾。沒有此選項時(shí),如果最後一(yī / yì /yí)個(gè)字符是(shì)換行符的(de)話,美元符号也(yě)會匹配此字符之(zhī)前(但不(bù)會匹配 任何其它換行符之(zhī)前)。如果設定了(le/liǎo) m 修正符則忽略此選項。Perl 中沒有與其等價的(de)修正符。 合肥網站建設公司
S 當一(yī / yì /yí)個(gè)模式将被使用若幹次時(shí),爲(wéi / wèi)加速匹配起見值得先對其進行分析。如果設定了(le/liǎo)此修正符則會進行額外的(de)分析。目前,分析一(yī / yì /yí)個(gè)模式僅對沒有單一(yī / yì /yí)固定起始字符的(de) non-anchored 模式有用。
U (PCRE_UNGREEDY) 本修正符反轉了(le/liǎo)匹配數量的(de)值使其不(bù)是(shì)默認的(de)重複,而(ér)變成在(zài)後面跟上(shàng)“?”才變得重複。這(zhè)和(hé / huò) Perl 不(bù)兼容。也(yě)可以(yǐ)通過在(zài)模式之(zhī)中設定 (?U) 修正符來(lái)啓用此選項。
X (PCRE_EXTRA) 此 修正符啓用了(le/liǎo)一(yī / yì /yí)個(gè) PCRE 中與 Perl 不(bù)兼容的(de)額外功能。模式中的(de)任何反斜線後面跟上(shàng)一(yī / yì /yí)個(gè)沒有特殊意義的(de)字母導緻一(yī / yì /yí)個(gè)錯誤,從而(ér)保留此組合以(yǐ)備将 來(lái)擴充。默認情況下,和(hé / huò) Perl 一(yī / yì /yí)樣,一(yī / yì /yí)個(gè)反斜線後面跟一(yī / yì /yí)個(gè)沒有特殊意義的(de)字母被當成該字母本身。當前沒有其它特性受此修正符控制。即:貪婪模式,最 大(dà)限度匹配 如:/a[\w]+?e/U匹配abceadeddd中的(de)abceade而(ér)不(bù)是(shì)abce,如果不(bù)加U修正,則匹配abce u (PCRE_UTF8) 此修正符啓用了(le/liǎo)一(yī / yì /yí)個(gè) PCRE 中與 Perl 不(bù)兼容的(de)額外功能。模式字符串被當成 UTF-8。本修正符在(zài) Unix 下自 PHP 4.1.0 起可用,在(zài) win32 下自 PHP 4.2.3 起可用。