PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
- <?php4 ?% T$ g" g J$ H
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",/ x j) Q7 d6 c, H }+ m) V
- "<b>example: </b><div align=left>this is a test</div>",
, H5 I9 t/ R& {! O - $out, PREG_PATTERN_ORDER);
" t9 [( L P1 v) L' V0 [; V6 k - print $out[0][0].", ".$out[0][1]."\n";8 M0 B2 x- K, w8 w6 T
- print $out[1][0].", ".$out[1][1]."\n";5 ~; [. R8 f- Y& y# J: u; C
- ?>
複製代碼 3 M! U5 J( V6 c/ H e4 \; a
本例將输出:
- <b>example: </b>, <div align=left>this is a test</div>
; V9 ]: Z1 R. y' R - example: , this is a test
複製代碼
) v' @0 W; ]1 l+ X5 e( O因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
" c+ _5 I, Y% [9 [
3 e2 W( _+ F2 t9 L+ ?" ?" S( s: f. b
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
- <?php
. D) x+ Z/ e4 s' o - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
' M. G& o6 H- U$ I) G* ] - "<b>example: </b><div align=left>this is a test</div>",
1 Y( ?" e$ k0 f4 R - $out, PREG_SET_ORDER);
) q. A: r0 A& Q7 v( I - print $out[0][0].", ".$out[0][1]."\n";, o+ k# h8 T6 |: Z% t' r# j' Z2 ^) `
- print $out[1][0].", ".$out[1][1]."\n";1 V) ^. B( R0 {+ c% S5 Q7 }* C
- ?>
複製代碼
4 @9 U# y3 B& ` @6 w A本例将输出:
- <b>example: </b>, example:! ?* F3 ]2 k2 n: ^' n! b
- <div align=left>this is a test</div>, this is a test
- I# y9 c l5 F- o; B4 V
複製代碼
; m" p1 U: K6 l' ?3 @! k! `9 l本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
: \! @6 I; s* L: x& O; ^9 [
5 B4 g2 T0 D- s; U4 M如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
3 V) S% Y; `% j5 d# c. L9 M8 ^例子 1. 从某文本中取得所有的电话号码
- <?php- k/ a+ Y6 j) _' V* |3 y" E
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",2 g, a" y- R$ o5 y" ?. l
- "Call 555-1212 or 1-800-555-1212 FREE", $phones);+ M: [- L1 ^) K" ~# S
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy)
- <?php |! ]. p- v5 R7 B$ s( D
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是- g _; B- w% Q
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中0 F# B, }2 e! D/ k1 U# h* w, g
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要' x$ [& Z! F$ M' D$ H
- // 多加一个反斜线。
9 R, r4 j. g5 x0 N% m! c8 D - $html = "<b>bold text</b><a href=howdy.html>click me</a>";2 m8 c& D5 A) M( `9 Q
* U) q+ p! \: Z- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
2 e& G, t/ C! m
}9 x& c2 T, E; S) O! O- for ($i=0; $i< count($matches[0]); $i++) {; l7 j4 z+ U& Z! |' E6 ?, v; X( |& u
- echo "matched: ".$matches[0][$i]."\n";6 E% B; j: M4 K3 ~" R
- echo "part 1: ".$matches[1][$i]."\n";/ K3 Z2 E2 \( m
- echo "part 2: ".$matches[3][$i]."\n";( C3 S( w- e/ F% P+ _
- echo "part 3: ".$matches[4][$i]."\n\n";
% c; x9 I; o E - }
: q# g$ v" l" c: G# w) U - ?>
複製代碼本例将输出:
- matched: <b>bold text</b>1 [. X/ F' k& O# A' k
- part 1: <b> j( C" c0 Y6 W. N+ m9 [- Z
- part 2: bold text
5 `3 X2 t ^1 ^ - part 3: </b>
3 y1 `4 N! b. u
6 Y- q, ?) j0 @6 i7 z- matched: <a href=howdy.html>click me</a>
' `* L" E/ x. w, c8 O F - part 1: <a href=howdy.html>, } D% U+ F7 @: R: `2 l
- part 2: click me* c6 J, e" t6 o/ Y: M1 h
- part 3: </a>
複製代碼