PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php% W/ _( u+ B1 N6 A; Q5 p6 o0 \% M
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",7 t. m& ^+ r. X+ n' O8 O0 } @
- "<b>example: </b><div align=left>this is a test</div>",! z6 Z: L7 g% c6 n: A1 Y! T
- $out, PREG_PATTERN_ORDER);
( Z; x5 J" }6 B' ^) r - print $out[0][0].", ".$out[0][1]."\n";+ g2 Z& f+ z D2 u' _0 d0 i
- print $out[1][0].", ".$out[1][1]."\n";5 t8 }' [5 l! X" b; I) _1 L
- ?>
複製代碼 1 J9 j4 A% p: L. R- d
本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>
. S' U( f g7 j9 g- R - example: , this is a test
複製代碼 ( r" S+ R/ A, J/ ~" O9 |
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
" E2 K7 i; y" m4 ~) X( ?
( E& I" V& Y/ T' o( r
* W3 U6 e2 d* _/ |; jPREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php3 O2 x2 W) }1 G4 q$ T0 U! X# J
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",/ T3 P9 [, i6 ^9 N) w
- "<b>example: </b><div align=left>this is a test</div>",
8 _/ U6 k% q" F$ q8 y* V* x - $out, PREG_SET_ORDER);3 k" d" S: T* b: P
- print $out[0][0].", ".$out[0][1]."\n";/ i) i; l: K6 O2 A, i2 H$ @6 P( f
- print $out[1][0].", ".$out[1][1]."\n";& j6 [& @# H' I" U4 P: r X9 p
- ?>
複製代碼
" G4 R4 j3 H/ e$ U) O本例将输出:
- <b>example: </b>, example:& e$ U/ ]" s. R* d$ v3 I& [
- <div align=left>this is a test</div>, this is a test
) K9 y8 t& i( k
複製代碼 : f( I6 U- z8 o4 a! b% \( K8 l
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
( { d- j4 x! f& i6 C+ R8 M" Y: r; i/ v4 q1 Q. d
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
" i2 c! a- o1 }
例子 1. 从某文本中取得所有的电话号码
- <?php( R. c+ p4 ~; a# s! c0 A' v2 h% m
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",/ w' |4 B Y8 b& }
- "Call 555-1212 or 1-800-555-1212 FREE", $phones);- n! s: _1 C P3 _' c& f
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php& a& u# r' `3 Y% g$ I+ ~' X8 u) z7 X
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是# @1 t2 A$ ?8 U+ T$ `( G3 e, c
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中
/ Q- T/ d i! G( @ - // 就是 ([\w]+)。因为字符串在双引号中,所以需要
( W* f" t2 D0 P; G* M - // 多加一个反斜线。
( Q, T* [9 n/ p; Q4 M - $html = "<b>bold text</b><a href=howdy.html>click me</a>";
' Q4 n$ c/ D: K7 ^* Y - 6 n2 s9 ~4 O0 D0 x; C, \: T
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
' r- J. ]4 q: E7 p$ o$ y1 E/ N
+ _1 t) D- ^7 ?- for ($i=0; $i< count($matches[0]); $i++) {
8 r2 E9 [2 M4 }9 V+ a7 e, ] - echo "matched: ".$matches[0][$i]."\n";8 U" {) I: V2 e
- echo "part 1: ".$matches[1][$i]."\n";8 ?/ b8 ~* l+ I- E9 ~
- echo "part 2: ".$matches[3][$i]."\n";
8 \7 v3 }; z; y7 H6 F# X8 r - echo "part 3: ".$matches[4][$i]."\n\n";; e" X3 L( j2 h$ T% |* J5 L3 U* e
- }. L1 U6 v; C) ^3 S8 [. [% N2 y Z
- ?>
複製代碼本例将输出:
- matched: <b>bold text</b># _, z# k0 k! ?% k K& c9 C
- part 1: <b>; S1 D+ W( `9 P: `
- part 2: bold text1 j3 Y2 w3 U, x0 M: I
- part 3: </b>
, c6 ]7 s/ m: e& o* ?; r5 O8 S8 y1 s8 {: z
1 d5 \8 t. s5 Q- matched: <a href=howdy.html>click me</a>$ ~( P' A9 x a. i/ {0 Y+ V
- part 1: <a href=howdy.html>8 O6 s8 T; h$ Y+ k* G
- part 2: click me4 @5 U9 U( M0 Y! T$ v6 q* Q/ H
- part 3: </a>
複製代碼