本篇內(nèi)容介紹了“如何使用preg_match_all”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)公司是一家專業(yè)提供北塔企業(yè)網(wǎng)站建設,專注與做網(wǎng)站、成都網(wǎng)站制作、H5頁面制作、小程序制作等業(yè)務。10年已為北塔眾多企業(yè)、政府機構(gòu)等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡公司優(yōu)惠進行中。復制代碼 代碼如下:
int preg_match_all ( string pattern, string subject, array matches [, int flags] )
在 subject 中搜索所有與 pattern 給出的正則表達式匹配的內(nèi)容并將結(jié)果以 flags 指定的順序放到 matches 中。
搜索到第一個匹配項之后,接下來的搜索從上一個匹配項末尾開始。
特別注意PREG_PATTERN_ORDER 和PREG_SET_ORDER
flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用沒有意義):
如果使用PREG_PATTERN_ORDER
對結(jié)果排序使 $matches[0] 為全部模式匹配的數(shù)組,$matches[1] 為第一個括號中的子模式所匹配的字符串組成的數(shù)組,以此類推。(即$matches[0] [0]為全部模式匹配中的每一項,$matches[0] [1]為全部模式匹配中的第二項,$matches[1] [0]為匹配每一個括號中的第一項,$matches[1] [0]為匹配每一個括號中的第二項)
復制代碼 代碼如下:
preg_match_all ("|<[^>]+>(.*)[^>]+>|U","example:
本例將輸出:
復制代碼 代碼如下:
example: ,
因此,$out[0] 包含匹配整個模式的字符串,$out[1] 包含一對 HTML 標記之間的字符串。
如果使用PREG_SET_ORDER
對結(jié)果排序使 $matches[0] 為第一組匹配項的數(shù)組,$matches[1] 為第二組匹配項的數(shù)組,以此類推。(即$matches[0] [0]為第一組匹配項中完整匹配的字符串,$matches[0] [1]為第一組匹配中完整匹配第一個括號中的字符串)
復制代碼 代碼如下
preg_match_all ("|<[^>]+>(.*)[^>]+>|U","example:
本例將輸出:
復制代碼 代碼如下:
example: , example:
本例中,$matches[0] 是第一組匹配結(jié)果,$matches[0][0] 包含匹配整個模式的文本,$matches[0][1] 包含匹配第一個子模式的文本,以此類推。同樣,$matches[1] 是第二組匹配結(jié)果,等等。
PREG_OFFSET_CAPTURE
如果設定本標記,對每個出現(xiàn)的匹配結(jié)果也同時返回其附屬的字符串偏移量。注意這改變了返回的數(shù)組的值,使其中的每個單元也是一個數(shù)組,其中第一項為匹配字符串,第二項為其在 subject 中的偏移量。本標記自 PHP 4.3.0 起可用。
如果沒有給出標記,則假定為 PREG_PATTERN_ORDER。
返回整個模式匹配的次數(shù)(可能為零),如果出錯返回 FALSE。
例子 1. 從某文本中取得所有的電話號碼
復制代碼 代碼如下:
preg_match_all ("/\(? (\d)? \)? (?(1) [\-\s] ) \d-\d/x","Call 555-1212 or 1-800-555-1212", $phones);
?>
例子 2. 搜索匹配的 HTML 標記(greedy)
復制代碼 代碼如下:
// \\2 是一個逆向引用的例子,其在 PCRE 中的含義是
// 必須匹配正則表達式本身中第二組括號內(nèi)的內(nèi)容,本例中
// 就是 ([\w]+)。因為字符串在雙引號中,所以需要
// 多加一個反斜線。
$html = "bold textclick me";
preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
for ($i=0; $i< count($matches[0]); $i++) {
echo "matched: ".$matches[0][$i]."\n";
echo "part 1: ".$matches[1][$i]."\n";
echo "part 2: ".$matches[3][$i]."\n";
echo "part 3: ".$matches[4][$i]."\n\n";
}
?>
本例將輸出:
復制代碼 代碼如下:
matched: bold text
part 1:
part 2: bold text
part 3:
matched: click me
part 1:
part 2: click me
part 3:
“如何使用preg_match_all”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!