tid=16929& int preg_match_all ( string pattern, string subject, array matches [, int flags] )
3 z9 [- c$ |4 f$ q/ b7 a2 H2 K$ F2 j4 J2 \7 J# j0 [
在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。 搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。 flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義): ( F. i: f) }- b: }" i2 U
PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。 - <?php
& c1 W8 ^0 U/ ?6 j! f' h/ A - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",& k* y# w3 x9 o" ~
- "<b>example: </b><div align=left>this is a test</div>",
' [1 {( t3 u* u - $out, PREG_PATTERN_ORDER);
5 W9 \3 d3 {" k( v- \) p% q1 E; F- e& g - print $out[0][0].", ".$out[0][1]."\n";
# H% L' W2 n# f) D3 K: l6 l3 q) ` - print $out[1][0].", ".$out[1][1]."\n";
3 h$ |! _9 Z; T - ?>
複製代碼
3 C& T' w9 A6 N1 d; t" P本例將输出: - <b>example: </b>, <div align=left>this is a test</div>
) W0 I! I2 ^7 H. B# ` - example: , this is a test
複製代碼
$ }: @6 l$ A0 d! o, t9 M0 i$ k* t! H因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。 : \( u4 d9 n% e$ d9 o
! o9 b, c! ?' t* _9 K! K
5 V5 v. G0 {- p! BPREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。 - <?php
9 {" h V6 P% t& T - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",# K: v- V' H) P( E. S8 m9 C
- "<b>example: </b><div align=left>this is a test</div>",0 y- ^4 k, W& g: \" h5 I
- $out, PREG_SET_ORDER);
# G# K' A7 L1 t) V0 ] - print $out[0][0].", ".$out[0][1]."\n";* I7 x' V4 K; }5 h
- print $out[1][0].", ".$out[1][1]."\n";4 D/ { B y6 Y$ \' T2 `
- ?>
複製代碼
9 M6 K0 Y) j1 [$ x5 O, A本例将输出: - <b>example: </b>, example:& A* Y/ C2 N6 K; F8 ?4 w; D
- <div align=left>this is a test</div>, this is a test; h- T$ E! I! r2 s1 _
複製代碼
5 E% p; P4 `0 @! q9 ~* j本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。 PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
5 I5 m" o8 c0 Q1 }" ]: \9 w' m2 f+ H# }7 J: _
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。 返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
2 P- z7 M7 r6 _0 a$ }例子 1. 从某文本中取得所有的电话号码 - <?php- ~+ y" {$ y: r" [8 F9 o$ T
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
- j- r% e- G! | - "Call 555-1212 or 1-800-555-1212 FREE", $phones);; T' g: J% i7 h" b7 W/ T
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy) - <?php
. S1 I, { }% u8 M - // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是4 k0 d0 o7 z; O1 h- W" y
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中
4 o. r. \, c9 ?# E - // 就是 ([\w]+)。因为字符串在双引号中,所以需要0 I$ `+ O+ f8 e5 h8 @' {
- // 多加一个反斜线。
/ Y$ Z2 u0 f% I - $html = "<b>bold text</b><a href=howdy.html>click me</a>";" F& W9 r" V$ ^: k) T
7 D+ c4 R9 a. G8 d: [# A- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
0 n1 v8 p, B0 ^. I, |+ w - - f# X% g+ I+ V G
- for ($i=0; $i< count($matches[0]); $i++) {
' _, P2 c1 ^6 w* L" o: S6 M$ e - echo "matched: ".$matches[0][$i]."\n";
q+ M8 V8 F6 e4 n$ R* l# z - echo "part 1: ".$matches[1][$i]."\n";
" m, o: {& b8 {2 }6 { - echo "part 2: ".$matches[3][$i]."\n";: w. g$ J5 j0 L {" A
- echo "part 3: ".$matches[4][$i]."\n\n";
/ T' L. Y: Q# B- G0 ~4 }: A - }# a" L j& P" c' K) @* I
- ?>
複製代碼本例将输出: - matched: <b>bold text</b>" v- Z6 R/ [$ ]! }. d! v* ~* |
- part 1: <b>
- C, ^& m* D) R - part 2: bold text
4 H& f. i: f# J2 h - part 3: </b>
* S8 A1 A; w7 ?# x0 |' B' ]
) Y( q) e# ]; k! X o3 {% I- matched: <a href=howdy.html>click me</a>
& \! M* E3 k& U4 q$ g5 {1 p! g - part 1: <a href=howdy.html>3 k1 o5 V% s% L4 O+ e q/ U
- part 2: click me7 S3 G8 A/ T- y7 P) m- G5 d$ Z- g
- part 3: </a>
複製代碼 3 {+ _# K. G% b- U% `
w' \- v* h; }, K' F
|