PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php3 V7 ^3 M0 }( b# Q1 y6 B
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
- ]8 G+ ]3 _' p7 d L5 G, P- | - "<b>example: </b><div align=left>this is a test</div>"," o- x. ^, F8 @
- $out, PREG_PATTERN_ORDER);
6 \: h& R6 q. h+ o. C - print $out[0][0].", ".$out[0][1]."\n";, U: O# m6 p f3 N6 D
- print $out[1][0].", ".$out[1][1]."\n";
+ ^' ^/ j: Q C( K& h$ N! V - ?>
複製代碼 4 d$ J2 S9 f9 C& K4 D
本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>0 T! q K0 S( D2 x8 z4 V( u! O
- example: , this is a test
複製代碼
; Z( r v" ?7 E& E& s因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
5 k" L" V7 X P# F; j3 C- I" Z( H8 X% Y. I3 ?
- C2 I ?/ S2 o, a
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php7 B* o, |: I6 x; s/ ~8 f
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
1 _8 N+ c) L* l - "<b>example: </b><div align=left>this is a test</div>",* s0 V, C, D+ P
- $out, PREG_SET_ORDER);
) k5 K$ m0 K& V, N) r - print $out[0][0].", ".$out[0][1]."\n";
2 q5 F3 c. v4 H! ^$ t - print $out[1][0].", ".$out[1][1]."\n";$ {! q7 C/ C! t+ K0 z* M. l
- ?>
複製代碼 , _( C% A- x ]3 |) z' {
本例将输出:
- <b>example: </b>, example:
; P3 n( l+ A8 t F/ s2 P - <div align=left>this is a test</div>, this is a test
8 e5 [ w+ R+ H) T! ?) B0 v! E
複製代碼
& U" @- m5 [/ }' ^本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
6 l" [; k: F2 w5 o6 x4 j2 ~# `. o' @! d6 c* s' y" M
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
/ t( s" a2 h- c3 r例子 1. 从某文本中取得所有的电话号码
- <?php
) Z$ a3 j3 s0 O D: H - preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
4 a( t% A! X: P- e - "Call 555-1212 or 1-800-555-1212 FREE", $phones);" k2 c7 `! i& W2 F' S, A
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php
6 [ H+ q \; v) ]% F - // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
! p3 H% z* B) w3 B I) I - // 必须匹配正则表达式本身中第二组括号内的内容,本例中
; |) f ~+ T- [( J5 D8 r - // 就是 ([\w]+)。因为字符串在双引号中,所以需要5 {# V z i2 }4 E5 |
- // 多加一个反斜线。; i. s" R4 G* g# }" P
- $html = "<b>bold text</b><a href=howdy.html>click me</a>";
9 N( y! \/ K4 Z U
; _$ r" Y- I% |) ^9 T7 w% T- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
9 h% C" g4 y; K
* m2 w; }6 B1 `5 Q1 }1 r" V1 ]- for ($i=0; $i< count($matches[0]); $i++) {
7 Q" \& P" O# l F A1 f - echo "matched: ".$matches[0][$i]."\n";
" ]! g* q. T4 e% N - echo "part 1: ".$matches[1][$i]."\n"; N! A9 y% A& u" d; `
- echo "part 2: ".$matches[3][$i]."\n";& t* Y6 x1 R9 C! W; a
- echo "part 3: ".$matches[4][$i]."\n\n";) M( p6 W6 G) _& y( M2 m
- }! U- N4 L# l. L* V! G+ @5 G
- ?>
複製代碼本例将输出:
- matched: <b>bold text</b>" `: Q" _$ k( k
- part 1: <b>
8 ~6 _7 B' K6 N, k+ O1 Y - part 2: bold text$ E' C$ H) X8 U4 H9 m" y6 u) X& y
- part 3: </b>
" J/ m) D) i( a' Y' q - / I: i/ V E2 G9 k, x
- matched: <a href=howdy.html>click me</a>
) \& F+ Z9 ?7 d$ n4 P - part 1: <a href=howdy.html>6 K5 ]8 O- }3 Y/ N
- part 2: click me0 S1 j* Y& e* K! s, D j6 l
- part 3: </a>
複製代碼