|
tid=16929& int preg_match_all ( string pattern, string subject, array matches [, int flags] )4 u5 D2 r; S; N3 j/ O1 T
/ a* q+ {/ j& v, C 在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。 搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。 flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義):
' p; F- B' G$ B1 a) n5 rPREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。 - <?php
2 P7 R) k/ ?" V- i8 {' w - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
$ e" B3 z' b+ a. m ^- e1 H* W - "<b>example: </b><div align=left>this is a test</div>"," ~- G+ a# n4 h3 l
- $out, PREG_PATTERN_ORDER);
* {, s4 \- _+ N+ z8 q' Y* s - print $out[0][0].", ".$out[0][1]."\n";. r6 Y( `/ A, v- S& F2 O+ X
- print $out[1][0].", ".$out[1][1]."\n";$ }/ X* J Y% d0 c; ]5 ?, v1 \
- ?>
複製代碼 0 f L5 d" e" _7 ]
本例將输出: - <b>example: </b>, <div align=left>this is a test</div>" V2 U- R* h8 m: s# S3 W. i( H
- example: , this is a test
複製代碼 ; _8 d6 m L" [- H T& J# w# E
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
6 i( Z1 i4 ?* {6 O9 h
5 n7 g" T% m& c7 `( ]) m2 Y7 _; x- e, t$ w/ M! Z% G
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。 - <?php
' N7 w& A8 |: }3 ~, o - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",0 u( X% S3 b* r
- "<b>example: </b><div align=left>this is a test</div>",
( T9 ] N$ Y: g, {) @ - $out, PREG_SET_ORDER);! K; Q( F0 k6 M9 ]
- print $out[0][0].", ".$out[0][1]."\n";
6 n |- z- Q: v: ? - print $out[1][0].", ".$out[1][1]."\n";
+ J" t$ Y4 `8 z7 V( H - ?>
複製代碼 / p1 i6 E: P9 R% X$ @7 m
本例将输出: - <b>example: </b>, example:
. H, ^! H; E. U. _6 O - <div align=left>this is a test</div>, this is a test8 h* B! \1 U7 l6 L5 k
複製代碼 # @3 r6 n( n3 n3 h8 w5 l/ u" V
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。 PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
! P. ]; r1 `; ~# S
. i+ X$ X8 R0 R0 e如果没有给出标记,则假定为 PREG_PATTERN_ORDER。 返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
5 l0 u6 P, j+ K例子 1. 从某文本中取得所有的电话号码 - <?php
: H# x) ?' ^, l/ I - preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
( n2 X: @+ U/ ]2 e! | - "Call 555-1212 or 1-800-555-1212 FREE", $phones);
3 y) \/ i( F" m4 _ - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy) - <?php
! n5 j( |; i8 ^# T: T, H4 b - // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
: P$ ?' Z) V3 A8 z. I. \# |$ O - // 必须匹配正则表达式本身中第二组括号内的内容,本例中# w4 s/ g: w; {* d
- // 就是 ([\w]+)。因为字符串在双引号中,所以需要
# G3 w+ j) c2 {) s& v0 p4 K' [+ @* p - // 多加一个反斜线。
# Y! M" j) a" |) v7 F - $html = "<b>bold text</b><a href=howdy.html>click me</a>";
2 q# r/ l2 X6 G0 k+ _9 x. i3 b- E& F
% k( L" k& Y) c- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
& M1 ]$ k/ |! s
- A, |8 d+ `0 O; S# e- }- for ($i=0; $i< count($matches[0]); $i++) {$ B4 B" m S5 x( n0 J
- echo "matched: ".$matches[0][$i]."\n";
1 o- g) z- W& j& y& ?9 \ - echo "part 1: ".$matches[1][$i]."\n";" g% ?. q% ~ U9 Y/ Q8 g
- echo "part 2: ".$matches[3][$i]."\n";
/ K1 |) z+ o- ?* k( j D. w9 P1 X: H7 V - echo "part 3: ".$matches[4][$i]."\n\n";% H, ^, E- y, ]4 f3 f3 n" j
- }
- f1 B f( o5 I: P# d - ?>
複製代碼本例将输出: - matched: <b>bold text</b>+ }0 V9 j9 O8 ~, `) M6 c2 f) n
- part 1: <b>. a8 ~( H# z+ g9 m6 o' s; \
- part 2: bold text
7 E% V( x/ O" }$ }5 ]* w% K - part 3: </b>% R6 B% _, J3 B0 S; @
% k5 v: f5 Y; S- B0 {2 `- matched: <a href=howdy.html>click me</a>- V. Y2 O9 D& `* S
- part 1: <a href=howdy.html>& D- R, P. c/ i0 T9 \0 f* L
- part 2: click me: j4 l$ E% b* `! M; ]! Q
- part 3: </a>
複製代碼
4 [6 O. }# d1 n7 b
' d4 q9 U9 d- u' r |