PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php
4 d1 C, n5 }8 U E, L - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",' T3 B* H, u W0 T u% h' g
- "<b>example: </b><div align=left>this is a test</div>",
$ S) }2 s1 K3 Q5 s8 F9 ^ - $out, PREG_PATTERN_ORDER);
# ], f# l% p7 ]5 G2 m - print $out[0][0].", ".$out[0][1]."\n";+ J- l% O$ p! y% q8 M" H
- print $out[1][0].", ".$out[1][1]."\n";1 M1 l8 m, g' H
- ?>
複製代碼 4 v% Z2 X8 S1 s
本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>: c$ V# |( }" W, q: t% |
- example: , this is a test
複製代碼
6 T, e7 Z& L- f6 ?0 |0 W! `因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
( \ u( ~) _: a- r; m4 S" l( w' Q+ p* a, _, D
6 y5 b' p: P. ~) i, s! f3 ]
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php- l( T7 v, q& K" k6 u
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
+ x2 ?/ K% z! h1 b# a - "<b>example: </b><div align=left>this is a test</div>",
% @. K2 |( b; W" M' k# {6 { - $out, PREG_SET_ORDER);
' c# H4 H; k0 m - print $out[0][0].", ".$out[0][1]."\n";
! G9 ^% q2 u. N - print $out[1][0].", ".$out[1][1]."\n";
; c& ~. [2 P% i( I# h - ?>
複製代碼
. G9 t1 r7 n+ j/ G本例将输出:
- <b>example: </b>, example:# }6 z6 i6 J' p
- <div align=left>this is a test</div>, this is a test. e, ?* ?% j- q( ?
複製代碼 ( l) Q: e* g2 i( w- G/ t4 f! _
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
4 M5 T0 R, n" H. I; [- F" x+ S
: L5 }- h. L& `: `2 F" R如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
3 G1 e/ j6 Z2 a2 p2 b例子 1. 从某文本中取得所有的电话号码
- <?php/ a+ @5 I2 v' W" [) j
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
( j- M* y& S2 P9 v: J - "Call 555-1212 or 1-800-555-1212 FREE", $phones);1 j) h9 Y, z! s( f
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php/ B7 |8 H+ o+ r1 N/ J. V/ v$ ~% L
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是, U9 D5 j- p% h: B$ y3 X. g1 v
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中* C% y+ f7 b: W' Y
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要2 j6 D& P) B4 N1 ~
- // 多加一个反斜线。( I8 r# Z5 b S% v7 _
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
3 [! C5 y! }. P: { - 7 w- T* a9 ?. U4 W- ~- m0 x
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);& U% A+ {9 z" T2 v
" q* ?+ U' G$ C- M5 N* u- for ($i=0; $i< count($matches[0]); $i++) {' K3 J- ~* ^# r [( m+ D
- echo "matched: ".$matches[0][$i]."\n";
# p. c0 }0 W9 ^9 p8 @9 \5 @! j5 w - echo "part 1: ".$matches[1][$i]."\n";# `! ^* {! H" t8 U& U$ d
- echo "part 2: ".$matches[3][$i]."\n";+ W8 R& m$ }. T5 V6 p
- echo "part 3: ".$matches[4][$i]."\n\n";, H7 F$ j" K; ?$ F" o$ v& I
- }
+ }4 V& R1 d+ m: Y - ?>
複製代碼本例将输出:
- matched: <b>bold text</b>
q' S& i$ S2 i l - part 1: <b>
, i; F0 S ~2 T' ]- U' E* q! W - part 2: bold text
+ d+ M p( f( _6 s2 t2 f$ D - part 3: </b>: l; C5 z9 a8 v9 d2 w+ Y; K! k
- . [/ r# a; ?4 x4 D/ n ~" M
- matched: <a href=howdy.html>click me</a>
P' I4 S. u) i/ O/ d& c) { - part 1: <a href=howdy.html>
" L7 L5 B0 O# `0 s9 [. L! S - part 2: click me7 Z" P) F# x6 x2 ~: Y
- part 3: </a>
複製代碼