|
tid=16929& int preg_match_all ( string pattern, string subject, array matches [, int flags] )
& v3 x' A% y' J1 K
& F* \0 R0 O+ Y( @; i 在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。 搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。 flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義):
0 f; a! F1 N- |& g- G: e0 b: CPREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。 - <?php. B* v! |: e; k. ^$ \
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",4 ?; v- y, m. K
- "<b>example: </b><div align=left>this is a test</div>",
. R& Q" c: W6 G) C, Y- {: v' q* A - $out, PREG_PATTERN_ORDER);. Q! d1 e$ i$ I; a
- print $out[0][0].", ".$out[0][1]."\n";6 n b! S3 S- G, a- F p3 C" {
- print $out[1][0].", ".$out[1][1]."\n";' l8 a% E9 \2 v4 C& q7 W
- ?>
複製代碼 1 g- [) {! w4 c, J) ?* n; w4 B" @+ e
本例將输出: - <b>example: </b>, <div align=left>this is a test</div>
: b. Z. s6 x) \. ? - example: , this is a test
複製代碼 " p- [+ W6 Z9 Q1 r
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。 & X0 D. h: w; h h/ O
, @' H! T6 ]1 o; [& b0 d4 [, @$ b% L
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。 - <?php# u$ I) s, D L, H7 C' q5 c
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",7 u3 K; x& K, H% Q) B% R
- "<b>example: </b><div align=left>this is a test</div>",
. c+ P/ z' U; U. r1 P" U - $out, PREG_SET_ORDER);/ Z7 Y+ Y* `9 y+ t
- print $out[0][0].", ".$out[0][1]."\n";+ d+ m9 g! E2 h/ U. a, O- T1 i
- print $out[1][0].", ".$out[1][1]."\n";
7 o# c0 d3 R. F7 Z- j- e% o. V - ?>
複製代碼
, [0 d6 C/ e" a. u* C本例将输出: - <b>example: </b>, example:6 Z6 M$ o5 R/ B0 ^( @7 ^( p$ F6 H
- <div align=left>this is a test</div>, this is a test& i4 U/ _6 ~ h4 m- ^4 n
複製代碼 6 [6 K6 |- n$ W
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。 PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。 _/ S7 X, J4 E7 _* p2 c% ~' k
- N4 S2 s- V& C0 q7 N如果没有给出标记,则假定为 PREG_PATTERN_ORDER。 返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。 9 b3 t0 v3 |! q" ~2 T. I E5 r
例子 1. 从某文本中取得所有的电话号码 - <?php
9 [" g$ X4 v- ?0 } - preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",0 U) P/ E( ~& R7 ]
- "Call 555-1212 or 1-800-555-1212 FREE", $phones);
: j2 U4 D. H" c- Y8 D - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy) - <?php0 t% l' }, g7 B
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
: ^: p. k0 X+ \& I2 i! l - // 必须匹配正则表达式本身中第二组括号内的内容,本例中- `! Z! A" a$ H7 s0 \; R
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要
# G) X* c( K. F - // 多加一个反斜线。/ ?& h& u6 ^, O7 N0 E2 }' {- ?
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
5 I) `9 M& g1 Y" Q# a$ S
j: o8 X5 F# _1 |- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);% k0 x0 x8 k* ?8 E; h
# m p: b8 W$ F/ t% p. P+ t& w0 B7 C- for ($i=0; $i< count($matches[0]); $i++) {* s j( A/ \# o6 B5 d' T# u! [
- echo "matched: ".$matches[0][$i]."\n";- h7 T8 v* z$ T4 N7 n0 y
- echo "part 1: ".$matches[1][$i]."\n";) |9 n' ?! s9 z, V/ [
- echo "part 2: ".$matches[3][$i]."\n";3 m$ ?: H# Q) ?( h- V& b
- echo "part 3: ".$matches[4][$i]."\n\n";
+ |3 F3 D) W+ q8 f- _( B - }
' V# x9 O. Q* Y2 y0 q2 D - ?>
複製代碼本例将输出: - matched: <b>bold text</b>
) y+ G% Z' D! K- X) h - part 1: <b>( f# ^+ k+ p. k8 Q2 O1 Y6 E. I
- part 2: bold text. R W2 }7 o* v$ m0 l
- part 3: </b>
. ~; q1 W/ | x0 o+ a% @ - % o( m" K; h1 x+ x6 V4 v; R9 p
- matched: <a href=howdy.html>click me</a>! q; g. ]5 T2 b; g; u! B
- part 1: <a href=howdy.html>3 J) C* r3 s" e. ^7 i3 u" h8 ]
- part 2: click me& t$ n- N$ N7 [
- part 3: </a>
複製代碼 5 b/ W6 F3 V4 n s# D
( m& I) q) i9 j |