PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php
8 w0 \; A: t2 x0 h; q - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
5 ], d7 q3 @7 v( {. s! C. S) U - "<b>example: </b><div align=left>this is a test</div>",
5 t2 `/ m2 H. f5 |) S; J9 ^ - $out, PREG_PATTERN_ORDER); n' m$ `9 M( D7 W0 ]
- print $out[0][0].", ".$out[0][1]."\n";: [4 A2 ]! T* U* s9 h/ l: Q
- print $out[1][0].", ".$out[1][1]."\n";8 R0 e) D3 L; h" p# J7 w
- ?>
複製代碼 6 E# W% M! W8 m1 j' |5 ?% q
本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>5 P) L' \( e4 l9 n! ]& t) r
- example: , this is a test
複製代碼
! u8 z7 C$ |# v- e6 q C因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
' q1 L: `$ E$ q ^7 r
# v5 \+ U! C9 s" s0 @2 J$ Z2 H V$ s% V0 B$ l; S
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php
7 n* K7 O) R# [# I6 r# F - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",, Q% C3 ?8 h) U; _3 Q, H
- "<b>example: </b><div align=left>this is a test</div>",
3 M; W# u6 B8 r7 Q - $out, PREG_SET_ORDER);
& ]$ f1 V- N2 E. E8 n0 R# | - print $out[0][0].", ".$out[0][1]."\n";1 H2 ~( b6 c- g, }5 g6 K! A$ i4 u
- print $out[1][0].", ".$out[1][1]."\n";+ H5 U8 E/ `" a, S! F1 w
- ?>
複製代碼
/ B' u7 h& U* T% T, W& t9 P本例将输出:
- <b>example: </b>, example:6 w: s0 m1 d5 d7 K! ?: R& u: T
- <div align=left>this is a test</div>, this is a test/ x! _5 |" L4 |1 ~6 n
複製代碼
4 Y! v1 D% L z本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
5 Q: r. Q) R* L+ m/ x/ i% L. I% M8 U P6 ]/ ~- S* ~/ x' \9 A( _5 O
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
3 F+ m# v# ]' X4 o) u6 ?例子 1. 从某文本中取得所有的电话号码
- <?php
8 r1 L$ V0 g9 H" U; P - preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",$ |7 l: U; v. v5 o, d+ F) ~' ?
- "Call 555-1212 or 1-800-555-1212 FREE", $phones);
6 O% R2 m4 _# { - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php* w) S% l i% M) M
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
4 X0 x0 H8 L8 G. G: n/ a - // 必须匹配正则表达式本身中第二组括号内的内容,本例中( F0 T; `) P& I
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要2 P' r( F+ G, c5 b# [' w6 r
- // 多加一个反斜线。0 h/ e$ X! S n6 w" n
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
# s( E; @3 ]9 i8 o
. B' N1 ]3 V0 r0 F- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
, y( r" ]. f( H9 _+ q' c
# S9 A: e" {& \$ {( t- for ($i=0; $i< count($matches[0]); $i++) {
8 @( s, @% o* p' H - echo "matched: ".$matches[0][$i]."\n";
! D) p/ C9 F/ l z6 h! E - echo "part 1: ".$matches[1][$i]."\n";
: A* s5 a: k" S$ N& k1 u; P - echo "part 2: ".$matches[3][$i]."\n";- R& Q# T5 s# P
- echo "part 3: ".$matches[4][$i]."\n\n";+ O) a1 ~: K/ |7 F6 ~
- }
2 C, I# y% K, \. Y9 U7 g - ?>
複製代碼本例将输出:
- matched: <b>bold text</b>2 k. |8 ]$ `* d" z; z' u
- part 1: <b>
) Z. k* [3 P4 y' o3 g - part 2: bold text
# z' d) d, D8 y+ I2 z1 M5 C - part 3: </b>
G0 N! U8 U8 w8 e: p W - + N: X# d" B" z1 m* W1 t" s
- matched: <a href=howdy.html>click me</a>
" W+ g1 C- P% d* C& u - part 1: <a href=howdy.html>
. W! O: x" Q6 v9 ~ - part 2: click me) |4 f7 y! U( I. L$ ^% ~
- part 3: </a>
複製代碼