PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php8 y0 w8 M9 g1 }$ w5 d# O3 L
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",% g) @6 q$ D4 W$ O& L1 x4 y
- "<b>example: </b><div align=left>this is a test</div>",
" ~% O1 M: h8 Y& W, O - $out, PREG_PATTERN_ORDER);* C3 m& ~3 j9 L G* c h2 x
- print $out[0][0].", ".$out[0][1]."\n";* K$ V5 ^( l& K4 \
- print $out[1][0].", ".$out[1][1]."\n";
8 i* o) H2 @- [0 U; S! \ - ?>
複製代碼
# u( O9 V& \; H; g' {本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>
0 \1 G3 ~9 I: ~# ~' U; i - example: , this is a test
複製代碼 8 f8 z7 r+ w) T, }0 _5 Q% X8 O
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
+ h5 v( I5 g, u5 ]& H, f2 ^
8 M# P$ D6 z" [
, o% G! C [: e7 S0 x o
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php
5 W3 t% z" N5 R: ]7 z - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",# y0 S; X" @4 I: o, p
- "<b>example: </b><div align=left>this is a test</div>",
& j, m: R, t6 `8 J/ k- ` - $out, PREG_SET_ORDER);
, Z* F, u& q' _* n$ l& W* ? - print $out[0][0].", ".$out[0][1]."\n";8 Y5 R4 I2 ~* q" |
- print $out[1][0].", ".$out[1][1]."\n";* c/ E! Z) c; K; L
- ?>
複製代碼 9 ~' e, K, e" o/ s) W) T/ C! }
本例将输出:
- <b>example: </b>, example:- A; [4 |7 g3 W, k1 H
- <div align=left>this is a test</div>, this is a test
1 Q' n0 o" A n
複製代碼 1 k4 c6 [8 a8 r/ o0 Q
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
& m/ J7 |8 {- I. b
. K4 B: q' `) `: ]如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
6 a! j( }0 d: _
例子 1. 从某文本中取得所有的电话号码
- <?php
* y+ x' @5 H( D- v; t - preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
) K9 M: m& ]- s7 ^ ?" m - "Call 555-1212 or 1-800-555-1212 FREE", $phones);
% `" y3 O* |0 m( b: M! ~! y - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php' ?# y( I+ p" h" d- r8 _3 D& E
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
/ m3 {1 [! a8 P+ ]3 ]3 u" L, I - // 必须匹配正则表达式本身中第二组括号内的内容,本例中
5 g& V. _! l) Y% ^ - // 就是 ([\w]+)。因为字符串在双引号中,所以需要
\1 b) Z5 p4 `( a - // 多加一个反斜线。
/ g! E5 v4 m; N7 n9 Q - $html = "<b>bold text</b><a href=howdy.html>click me</a>";* O* ^ r; Y* @; g1 @
$ _8 n/ p+ ~& i1 V/ [6 w k- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
' F1 L k3 {% B% j! P5 S( Q# k Z - / w7 w9 Y3 s7 B( j0 _
- for ($i=0; $i< count($matches[0]); $i++) {
( c- g; L ]+ @" z3 v9 F - echo "matched: ".$matches[0][$i]."\n";
: u2 J3 [( q* l+ K - echo "part 1: ".$matches[1][$i]."\n";
6 @& W3 t4 c9 E - echo "part 2: ".$matches[3][$i]."\n";2 f- `- e& ]6 \
- echo "part 3: ".$matches[4][$i]."\n\n";
$ N- W4 ], a5 B. E - }" c7 M( W! _5 v- X. M; Q8 c, {7 v
- ?>
複製代碼本例将输出:
- matched: <b>bold text</b>% P# K, J" E$ l5 r& G
- part 1: <b>" P5 |" o. ?$ o1 W% i k
- part 2: bold text
5 M- `6 y H0 \* H/ ?' K! k+ S - part 3: </b>* i; b" `6 u2 [, M$ K
- $ a; R9 O) A( E" m2 C- W, d, o
- matched: <a href=howdy.html>click me</a>4 f, f. n1 U. \: K- t; h# o
- part 1: <a href=howdy.html>1 S0 ], x+ s6 ?7 [: r1 ]
- part 2: click me# i7 y) J6 J: O5 ]; d$ W
- part 3: </a>
複製代碼