|
tid=16929& int preg_match_all ( string pattern, string subject, array matches [, int flags] )! M- O5 a4 \7 V2 D5 k4 ~
2 [" f) A l0 I: `2 P2 n* ` 在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。 搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。 flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義):
- i' n4 I) m: d. L! L: A" T" ~1 vPREG_PATTERN_ORDER對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。 - <?php
6 {8 \8 I$ C: G5 W0 ?9 j( L - preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
5 k% J9 u6 N# E4 m0 } - "<b>example: </b><div align=left>this is a test</div>",
# S; \- Z& T& P0 U. a - $out, PREG_PATTERN_ORDER);
/ I- c( R- l; x. R# N/ q# E' L - print $out[0][0].", ".$out[0][1]."\n";
' W j% F; b' M6 Z - print $out[1][0].", ".$out[1][1]."\n";
: t. n7 e. P# v( Z" R* N - ?>
複製代碼
# T$ x) [. M3 x$ ]4 _5 K本例將输出: - <b>example: </b>, <div align=left>this is a test</div>1 l. o( ~& J/ k9 n6 l2 G
- example: , this is a test
複製代碼
+ l9 X# I) c8 W6 Y6 w" j, G+ R因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。 # o) x- R* H2 n0 P
0 ^. a2 O$ c7 b/ V: Q* F7 e
U; \9 |$ |" D b
PREG_SET_ORDER对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。 - <?php$ c5 P9 a7 w$ r6 ^3 N
- preg_match_all ("|<[^>]+>(.*)</[^>]+>|U", K z4 G S! P) \) W
- "<b>example: </b><div align=left>this is a test</div>",
, ?5 R' \$ W( p4 O3 \ - $out, PREG_SET_ORDER);- k; h8 B' I- z
- print $out[0][0].", ".$out[0][1]."\n";+ l4 `. n* Y$ f$ d
- print $out[1][0].", ".$out[1][1]."\n";
& l, A* V6 b& N3 f; E2 S - ?>
複製代碼
( N6 Y; |* u7 q- s+ x! ]/ X4 \本例将输出: - <b>example: </b>, example:
% w7 H* G# g3 B/ |2 J+ R/ T5 u - <div align=left>this is a test</div>, this is a test7 |8 m2 k- T$ O) X. }: `1 }
複製代碼 ! v- A) M1 P. V2 o: B* D d
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。 PREG_OFFSET_CAPTURE如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。 4 ?. a2 z# @# u: N3 R" G, w
3 a B% H3 U8 [( q$ s9 a' v: d# x
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。 返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。
& s# r# @( K2 L/ D$ w" u4 @6 l; [( H8 B例子 1. 从某文本中取得所有的电话号码 - <?php- H) W& G6 i2 l6 G+ c" G$ f8 Q
- preg_match_all ("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x",
. M6 }' R8 ~7 L, s - "Call 555-1212 or 1-800-555-1212 FREE", $phones);
0 q6 Z- \6 P5 C2 \2 B8 S+ F - ?>
複製代碼例子 2. 搜索匹配的 HTML 标记(greedy) - <?php
% X, F: u! @! O" R( j, ?: E - // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
" a. Z- v' j2 x- |- P" r1 F - // 必须匹配正则表达式本身中第二组括号内的内容,本例中
6 u( H* l, V' J' E - // 就是 ([\w]+)。因为字符串在双引号中,所以需要( K1 x: F8 k9 h* h* k" D
- // 多加一个反斜线。
: M1 b. o' U- Q. e2 j( f; `) m' Q - $html = "<b>bold text</b><a href=howdy.html>click me</a>";
. v, q0 D. \3 ]8 p4 @: d - G! r+ E. C% ^5 L
- preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);" F8 u( i, f! Z+ _5 a
, [ D0 z7 N( A6 l( h" ]9 S- for ($i=0; $i< count($matches[0]); $i++) {: I5 i* u0 @, F6 H
- echo "matched: ".$matches[0][$i]."\n";8 Y1 y/ p0 R* |
- echo "part 1: ".$matches[1][$i]."\n";
& C9 g( L E, I! {$ m - echo "part 2: ".$matches[3][$i]."\n";
5 U0 V, N- B) A+ W1 o5 o- p - echo "part 3: ".$matches[4][$i]."\n\n";8 q5 [- O: z1 J. } [$ L* W
- }
3 x6 [: m9 q) O7 u - ?>
複製代碼本例将输出: - matched: <b>bold text</b>
$ o0 F: Q9 U" w* K4 e3 d/ [2 u - part 1: <b>
" B0 h: Z G1 h$ K Z. C% F% I - part 2: bold text$ u! A/ E2 O9 O7 @, U
- part 3: </b>, O- n) N$ F: S' i3 c7 H* b/ |
8 e. Y+ t: B/ r# h! b! Z4 Q7 \- matched: <a href=howdy.html>click me</a>
$ |; Q/ |2 k* }0 U8 P - part 1: <a href=howdy.html>
" o7 d- Y/ l. [7 K8 N - part 2: click me# d9 E. |/ A, s$ {. v6 _
- part 3: </a>
複製代碼 $ `- t& j# E/ R9 D% Z
h8 p' v3 j' Y# u# r2 a, C3 V7 M
|