PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php
2 ^4 z9 @0 `0 ^ R; c) L - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",7 U. c% w; F* K; L ]0 l
- "<b>example: </b><div align=left>this is a test</div>",0 `* ?( w8 M/ u4 u3 ^- R; G
- $out, PREG_PATTERN_ORDER);
9 }1 H. g9 ]& a6 G9 d/ @ - print $out[0][0].", ".$out[0][1]."\n"; J8 U1 f- q/ S
- print $out[1][0].", ".$out[1][1]."\n";
E+ ^3 `, K, [' U b2 B - ?>
複製代碼
1 g/ E/ I& N1 y6 A, Y) j本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>4 P7 [8 s9 i e0 L; o: I5 }, m
- example: , this is a test
複製代碼 q, G+ I3 \2 e
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
4 h B, J8 ^. @0 u' p: i; {
5 l* K) N* T6 C9 W- s, F R- n# b7 X4 ?' y" M4 N! M" a
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php
# j% G- q0 L" I* X3 c4 } - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",% {0 g: z9 F7 u
- "<b>example: </b><div align=left>this is a test</div>",2 f9 l+ \; d% h0 v
- $out, PREG_SET_ORDER);
4 c2 Q7 n3 q6 R) F( W2 C - print $out[0][0].", ".$out[0][1]."\n";
6 I& d, e/ a6 y; G - print $out[1][0].", ".$out[1][1]."\n";
' @; `" i4 z3 \ - ?>
複製代碼
3 R3 a- z6 q y2 r) {本例将输出:
- <b>example: </b>, example:8 f9 _$ O! m1 d m
- <div align=left>this is a test</div>, this is a test
4 U1 z. @3 D0 M/ v n8 T
複製代碼 + h' G' T# s: d1 Q
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
2 Y0 i! ^. ^* P# U4 E# |: c7 |
& S( l$ I* r7 d, H, X" `% v- P; Z如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
! k2 _6 Z' t& s" T例子 1. 从某文本中取得所有的电话号码
- <?php x( l- p D* e0 B# U6 y5 ]
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",8 f9 U5 Q" \4 W+ @
- "Call 555-1212 or 1-800-555-1212 FREE", $phones);
6 \& a2 Y" \/ E& s/ G8 r - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php
* o& v+ P0 l" b) {- l: m - // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是. A. C5 [0 K; _4 p
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中
$ D2 M. c3 z, V5 g" N - // 就是 ([\w]+)。因为字符串在双引号中,所以需要
3 A5 ^4 `" p8 w; | - // 多加一个反斜线。) p) Q7 t- e& o6 Y$ s% ^
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
" F" j" e; B$ a4 N& t% n - 2 x+ L2 n* x8 a7 @4 _ T7 u( [
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);2 v, q* }6 {1 ]
- # W% \+ v, {' @) R# Y
- for ($i=0; $i< count($matches[0]); $i++) {
% _: h. |4 j5 n3 a" f5 ?9 O - echo "matched: ".$matches[0][$i]."\n";. g) g! g2 ^$ d r3 s
- echo "part 1: ".$matches[1][$i]."\n";
' h8 l* Y! B, Z - echo "part 2: ".$matches[3][$i]."\n";
3 g/ ^) Y2 [ ^/ z" E# @/ V - echo "part 3: ".$matches[4][$i]."\n\n";2 n- X7 F& S# u8 N* x; W
- }/ V8 n u% |3 M6 w1 q( b# x
- ?>
複製代碼本例将输出:
- matched: <b>bold text</b>9 k2 q; h' |' u' R. {
- part 1: <b>! n; M4 r+ T# h4 V% ]
- part 2: bold text
2 T/ V" v6 l1 |& x - part 3: </b>+ \4 J F, N3 i6 Y! P
0 n r: P" M6 e4 S# l8 K- matched: <a href=howdy.html>click me</a>
: P$ f; U/ b( I/ p! ^ - part 1: <a href=howdy.html>
9 `' V. d1 p% `( | - part 2: click me
& j, D0 J; ?% d- v" v& I" m - part 3: </a>
複製代碼