tid=16929& int preg_match_all ( string pattern, string subject, array matches [, int flags] )+ I% k2 }4 x( y1 A) B6 `" N
0 X' H" \6 P; I7 d6 A6 h
在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。 搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。 flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義): 0 ]9 e6 Z& C) [! @ t! Y |. d
PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。 - <?php
8 u% ^7 o; f# s) w4 [- f - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",2 }/ n' b t# l1 h2 T( [# ~8 {! N
- "<b>example: </b><div align=left>this is a test</div>",
C' Y* {# U& r5 B' X8 s. ~, N - $out, PREG_PATTERN_ORDER);3 S& y& D, O4 C, n: u3 u
- print $out[0][0].", ".$out[0][1]."\n";' s/ }1 A7 Y6 Y) `' {
- print $out[1][0].", ".$out[1][1]."\n";8 W* ]9 p8 k$ Q% r7 s% r% h7 c$ p
- ?>
複製代碼 # p0 Q4 R2 r* |' E; a
本例將输出: - <b>example: </b>, <div align=left>this is a test</div>
. R+ o+ v! S4 q - example: , this is a test
複製代碼
- i5 s2 A% H' H2 L因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
: I, l! t% \( |" C1 ~* F* a! p2 n' Q: A: s- X4 Z/ p" H% H% V# M) A
H2 v+ D' v7 `" z0 S
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。 - <?php) T% \. R) R) Y: L7 C, e6 {
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
1 c- L: t6 P# `9 s - "<b>example: </b><div align=left>this is a test</div>", d4 J4 U5 c+ G4 z9 J
- $out, PREG_SET_ORDER);$ P; f- _7 b- ], q. N
- print $out[0][0].", ".$out[0][1]."\n";& [% q+ q6 ~4 [4 j/ q. a' b# u
- print $out[1][0].", ".$out[1][1]."\n";$ _; a8 ^/ q/ I3 L8 H$ a* Y* x
- ?>
複製代碼
6 X# l% d) N! p本例将输出: - <b>example: </b>, example:
+ _4 r3 F* M- N$ H) d$ S - <div align=left>this is a test</div>, this is a test" W7 X2 O( E( d0 N/ {, I
複製代碼 9 G9 l$ T+ b5 t. Z2 S2 K/ A2 r2 _
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。 PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
) Y/ K8 \7 M8 \2 @8 [
; {; e7 Q3 X: u% v$ T如果没有给出标记,则假定为 PREG_PATTERN_ORDER。 返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。 & D# S& z7 _ b P4 Q9 w: @
例子 1. 从某文本中取得所有的电话号码 - <?php. a( q! s$ f9 }* }
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",3 T9 i8 s: S) {5 {: _
- "Call 555-1212 or 1-800-555-1212 FREE", $phones);
/ X, U% F, L$ p2 \! ^3 R4 c# Q( c - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy) - <?php6 T( c! @6 P% P7 h+ |; X& b
- // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是" ?# B4 J* I4 Y0 x
- // 必须匹配正则表达式本身中第二组括号内的内容,本例中9 P; y3 X+ i7 F' X8 v! C; y. m
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要
) `$ P. i' m( a" N6 [( u9 V H0 k - // 多加一个反斜线。
5 D, E' n+ Z: ?- E+ L - $html = "<b>bold text</b><a href=howdy.html>click me</a>";
: ~0 m, C3 ?% h0 E* n! G - 9 q" ]6 [* l. v( U
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
4 M5 e' U, T+ T - # o2 ~& `5 x( l u! H8 f
- for ($i=0; $i< count($matches[0]); $i++) {8 j1 I; M* r* D4 g
- echo "matched: ".$matches[0][$i]."\n";% s0 z: C; N( G# _% M
- echo "part 1: ".$matches[1][$i]."\n";
' f- g+ w2 L$ D7 Y# u* r. `; m - echo "part 2: ".$matches[3][$i]."\n";. V. m* V* z$ J
- echo "part 3: ".$matches[4][$i]."\n\n";7 P* y+ G0 ^; _6 v/ V. U
- }
) L' o G1 J. }: _ - ?>
複製代碼本例将输出: - matched: <b>bold text</b>
7 U; ?" _# U* |. p - part 1: <b>5 n- z1 J+ b5 l
- part 2: bold text
* f4 J: L, g3 {' y - part 3: </b>4 A9 e, B6 ? _
- 6 N3 F+ s3 g; p
- matched: <a href=howdy.html>click me</a>8 D% d/ y$ u5 ~
- part 1: <a href=howdy.html>
1 Z& K, o& i5 B' T6 a; I# X - part 2: click me
$ N- _# D- P6 J/ \0 X1 S - part 3: </a>
複製代碼
# a( U4 k# D$ y% |7 r
7 ~9 p( E2 I- H4 w8 G |