|
tid=16929& int preg_match_all ( string pattern, string subject, array matches [, int flags] )6 K/ C: i2 J Y9 z+ m
z5 I+ B/ ]7 C' ` H8 g e7 m
在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。 搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。 flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義): ! I" d- p* D" ]! A8 T4 G$ {7 {
PREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。 - <?php
5 T5 g# ~2 |, S0 T3 |$ `# y - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",; K: y+ ?' S2 m
- "<b>example: </b><div align=left>this is a test</div>",
3 D/ e& V& u6 x6 x, d3 P - $out, PREG_PATTERN_ORDER);
- H; {# {8 @5 s' F3 M. Q2 x( `. c& I - print $out[0][0].", ".$out[0][1]."\n";! V8 O5 E' [0 K) w9 h& m5 L0 ^
- print $out[1][0].", ".$out[1][1]."\n";: v- }# H( B+ o+ W$ k
- ?>
複製代碼 ' m. Q& Q5 J6 W; C0 k4 |0 F
本例將输出: - <b>example: </b>, <div align=left>this is a test</div>
& l! o3 @9 p/ E% O( H7 X: h - example: , this is a test
複製代碼 $ e" i- M" V# |% k+ Z& A' l' l
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。 7 q# g; E' ]. R g7 P& S
) E7 @/ ` P( F! b. O0 k9 R+ d% A8 A
! Z0 v6 \, y% p- |& n I% `PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。 - <?php" b$ a6 I8 b8 D: z- }' s
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",; ^ o' T- `3 m( a4 |5 g$ }
- "<b>example: </b><div align=left>this is a test</div>",
, S! R3 Z q0 G) K" T- ?. g - $out, PREG_SET_ORDER);. A* L, C6 n& w' {! Y& |
- print $out[0][0].", ".$out[0][1]."\n"; u) `! T! e9 R& s* _$ w# f
- print $out[1][0].", ".$out[1][1]."\n";. d5 k' L1 w L! A( ^
- ?>
複製代碼 9 s9 n4 V: [0 V2 `) {
本例将输出: - <b>example: </b>, example:
6 W8 g& M# ~! ?# [: S - <div align=left>this is a test</div>, this is a test
( {3 F; ^1 e. {4 b1 Y( J
複製代碼 ) ^$ t! D6 ~' C( P, _
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。 PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。 - ]% _ w- \. q* ]
; {* B0 b! @9 T5 z如果没有给出标记,则假定为 PREG_PATTERN_ORDER。 返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
9 p! s7 G! c0 E/ b3 \0 N例子 1. 从某文本中取得所有的电话号码 - <?php
' u* a. V! X) L: R - preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
! S3 ?7 b* p+ o2 H" r - "Call 555-1212 or 1-800-555-1212 FREE", $phones);: [0 L8 [0 z& P( x2 _
- ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy) - <?php
! ]- @/ [! e' O: f - // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
; T7 q4 N: @3 S( { - // 必须匹配正则表达式本身中第二组括号内的内容,本例中: H" z" o* B5 ~% d
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要
& |. v ~7 M! \+ B: h1 ` - // 多加一个反斜线。
: ~/ Q0 k3 C! @& A% Q; { - $html = "<b>bold text</b><a href=howdy.html>click me</a>";
/ v* S% u' t0 e; \& O$ t; L; C - ) @' X! O2 c; S8 S" w- O6 K
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
7 D0 f9 Q& g% e j+ O' k" o
! y+ q8 t. B0 j9 P7 J- for ($i=0; $i< count($matches[0]); $i++) {
' q( c# J( Y- v( \5 u - echo "matched: ".$matches[0][$i]."\n";
3 b- {$ H, b- ~ J - echo "part 1: ".$matches[1][$i]."\n";
2 i( n% M: f- c - echo "part 2: ".$matches[3][$i]."\n";4 b: @* g$ u# L
- echo "part 3: ".$matches[4][$i]."\n\n";
& G) X1 S/ [6 l! H - }8 e; Z8 y. P5 T( P0 a- o1 @0 x
- ?>
複製代碼本例将输出: - matched: <b>bold text</b>
( H6 M; Q3 k2 A& g( w M - part 1: <b> W* t0 ^3 T$ `
- part 2: bold text
/ y2 g2 E o/ E& A2 _9 ?2 r7 X - part 3: </b># {# r6 e- F2 M: _& s. J: K1 M
- . q* Y. X+ G* V2 C
- matched: <a href=howdy.html>click me</a>
5 ?* ^' c4 N! i2 e! h& M* |, W - part 1: <a href=howdy.html>9 i3 o0 \1 b/ m" J; v
- part 2: click me
$ H7 O0 f, U) Y9 ^4 O" L) F; @ - part 3: </a>
複製代碼 5 D1 Y. B4 Q9 B: F" v8 j1 B
8 u3 o0 I! _! o$ _6 s& D
|