PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php0 f1 |. u2 H2 ]) \; \4 ]4 e
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
0 z! a/ P% G' Y+ v! w1 E - "<b>example: </b><div align=left>this is a test</div>",
! d n0 Z2 v o% F - $out, PREG_PATTERN_ORDER);9 N4 P4 M$ Z" a
- print $out[0][0].", ".$out[0][1]."\n";
* d3 Z5 i- z8 f( Y& J - print $out[1][0].", ".$out[1][1]."\n";. {% ]5 x v1 V3 p9 G: [6 `
- ?>
複製代碼 * R7 Q. x; u( x$ U
本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>9 q1 q' S B8 `5 y
- example: , this is a test
複製代碼 2 p8 p. O7 L4 Z0 l' @. A6 B, \+ ]
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
# U {& o( g9 w/ U( ~2 G/ M1 X. e- U! d. l' X+ q; ?8 c4 l' S6 T
- m, B$ @* M1 n; p6 |
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php9 I0 a0 A# a9 y! [
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",% u4 W, v3 u1 X' n& h
- "<b>example: </b><div align=left>this is a test</div>",& J3 s" w% _" ?& ], y S. ]
- $out, PREG_SET_ORDER);5 D: Z/ u$ u$ i
- print $out[0][0].", ".$out[0][1]."\n";
" |9 m q6 L( X - print $out[1][0].", ".$out[1][1]."\n";
1 ^* X' b( f, e/ z/ y* j* b - ?>
複製代碼
* g. Q( L5 Z8 t- e2 \- U G7 J本例将输出:
- <b>example: </b>, example:2 U5 c* G: o! s6 s+ k
- <div align=left>this is a test</div>, this is a test
' B! f3 f* K% o0 B+ _
複製代碼
" O7 }1 s: b# L$ f本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
( J) Y; S% n' `- k8 s5 @1 `' L/ b8 d2 `' v6 q* O
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
. s9 s. h+ Y/ w) S& k" u例子 1. 从某文本中取得所有的电话号码
- <?php) D7 ^ w0 M) c9 f( m6 X( T" K$ Q2 z% `
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
2 @/ l: D5 M5 ~7 {- W8 B - "Call 555-1212 or 1-800-555-1212 FREE", $phones);
( L4 q9 K$ }* W8 H0 z2 n7 S - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php7 g& m+ Z8 t+ \: F7 g: {
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是' k/ B. X( n6 _6 A5 e. p
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中7 H! D- U% Q+ ?& V6 t ~
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要 I: m6 A4 S8 c6 B+ F) c2 w
- // 多加一个反斜线。. G3 C* D0 B0 o3 @ U! M
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
! e3 G9 X0 W9 e1 K9 q, A - 6 ~2 ]+ z2 ~1 x' t. F
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
# O5 o; z7 t3 V# Y
1 ?, \( G' i: V: i) P" {" |* k4 y- for ($i=0; $i< count($matches[0]); $i++) {
! u8 d, r% }' b) b - echo "matched: ".$matches[0][$i]."\n";& j2 |, ?% {8 {! a; @
- echo "part 1: ".$matches[1][$i]."\n";
+ b) o0 `3 Y1 Q! `9 j - echo "part 2: ".$matches[3][$i]."\n";
) l8 m+ r2 b+ C2 ~, q - echo "part 3: ".$matches[4][$i]."\n\n";: c, X2 e( \2 X1 n$ E2 o0 g
- }! x0 |$ ^& B# {* T; A. t4 ~# s
- ?>
複製代碼本例将输出:
- matched: <b>bold text</b>
- u( d3 X1 \. L2 S - part 1: <b>
. u0 \+ w7 N/ h K- r4 E/ P - part 2: bold text
# D+ h& P5 B0 b& ` - part 3: </b>
. R. ] O" y8 P& P! [$ E - & Z2 U- C2 i) c) L3 q% a9 J$ b
- matched: <a href=howdy.html>click me</a> l. r/ F* o. ?- z3 r
- part 1: <a href=howdy.html>
. c l: ~/ E. `- V - part 2: click me2 W! S" R7 i9 ^6 N! q' }% }- l4 X; }
- part 3: </a>
複製代碼