PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php
8 `5 B) ^) X: q3 ^2 y; Q. ^ - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
, C: Z4 n) |0 C9 `9 R! N - "<b>example: </b><div align=left>this is a test</div>",
. [8 E8 z/ B; v - $out, PREG_PATTERN_ORDER);
~ @0 N1 w e) a( ^ - print $out[0][0].", ".$out[0][1]."\n";
" @! P* ]: i, w+ M, m3 x3 F+ p - print $out[1][0].", ".$out[1][1]."\n";# f9 ?+ c# i; \$ ]/ J5 @- z
- ?>
複製代碼
5 @" M* K7 O5 d4 ~0 G3 r& c: `本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>* e- J- @ }( A. n4 ^6 Z6 D
- example: , this is a test
複製代碼
; p6 z; W s4 W: b# B, ~因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
/ O4 X U+ k V7 V
( o$ S( |- i- Z4 v9 a: }
. F* j q- z. p; s9 W HPREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php0 l7 J# o6 z* g: e7 P
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",, \1 q* c5 S+ w+ ~3 _0 ]/ l
- "<b>example: </b><div align=left>this is a test</div>",4 |% ?; {# m) `9 H
- $out, PREG_SET_ORDER);4 S K; e4 r' q& ~
- print $out[0][0].", ".$out[0][1]."\n";
- @1 q- o9 l3 { - print $out[1][0].", ".$out[1][1]."\n";
! a4 l1 ]) ?" s0 O J; ?. t w - ?>
複製代碼
6 A; H( Q! [8 S' d: Q本例将输出:
- <b>example: </b>, example:7 a2 S: R4 c0 N% |5 F! ~' W, ]
- <div align=left>this is a test</div>, this is a test Y4 ^( z; F$ B* {
複製代碼
1 s4 X, D- i5 `- ~' ]" B; ?本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
! D5 H$ }. v4 I$ {- O, z/ N
: X# F; m5 N* B) V0 Q- J a
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
% o' a; }9 D% t2 j$ T7 ^
例子 1. 从某文本中取得所有的电话号码
- <?php4 h4 n2 R" }$ q5 M
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
( w+ s% M: F! `: ~/ C% I - "Call 555-1212 or 1-800-555-1212 FREE", $phones);! ^ O9 z/ J% U8 _1 `3 P
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php* i3 D9 x' ^% w& }, a( c
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
( r3 F4 S7 W4 J" i- H8 z - // 必须匹配正则表达式本身中第二组括号内的内容,本例中' B( v, ]( X( T9 G. r
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要2 R( q; z, n! {3 p% R1 w
- // 多加一个反斜线。1 @9 _- |1 ?9 Q: G; a9 }
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
, q, E# R& S2 u% \ - / w0 [2 j- v* Q' u1 m' V
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
/ o* ^* z, ]' g! B- H
. }8 @! y' l+ x/ S0 L0 Y# X( C- for ($i=0; $i< count($matches[0]); $i++) {
9 \8 t% x8 f* d% E$ D- x6 r' Q - echo "matched: ".$matches[0][$i]."\n";( T. T! Y9 D1 ~6 A( ~
- echo "part 1: ".$matches[1][$i]."\n";- ]4 L$ |7 z8 A. U
- echo "part 2: ".$matches[3][$i]."\n";5 w# ~( a" Y2 |
- echo "part 3: ".$matches[4][$i]."\n\n";
9 a8 |1 C+ z% v0 A& L9 D - }3 ^5 q; Y7 e' Y8 b! y
- ?>
複製代碼本例将输出:
- matched: <b>bold text</b>7 d1 @' m" q# }
- part 1: <b>
2 N) }9 v8 d" i6 K5 p - part 2: bold text
) `+ u% c1 h3 b* `& t: D/ Q - part 3: </b>
5 t! s% H+ r6 U* ?; A$ w - ) Y2 N. I) {. {6 X$ x' ^% M% S. B3 C
- matched: <a href=howdy.html>click me</a>
/ `) w* o' E" S- x8 G. W' E - part 1: <a href=howdy.html>
8 [; y# Q4 h+ @3 p9 L8 b - part 2: click me
- B% `: [! }* l* U& J. y - part 3: </a>
複製代碼