52AV手機A片王|52AV.ONE

標題: php中preg_match_all 用法 [打印本頁]

作者: IT_man    時間: 2015-8-28 10:27
標題: php中preg_match_all 用法

int preg_match_all ( string pattern, string subject, array matches [, int flags] )# i* y0 p( _) S5 J3 P5 c
5 h' u' K5 T, G5 y

在 subject 中搜索所有與pattern 给出的正規表示式匹配的内容並將结果以 flags 指定的順序放到 matches 中。

搜索到第一个匹配項之后,接下来的搜索從上一個匹配項末尾開始。

flags 可以是下列標記的組合(注意把 PREG_PATTERN_ORDER 和 PREG_SET_ORDER 合起來用没有意義):


, u# P, n3 X7 `) ]PREG_PATTERN_ORDER
對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
  1. <?php
    8 w0 \; A: t2 x0 h; q
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
    5 ], d7 q3 @7 v( {. s! C. S) U
  3.     "<b>example: </b><div align=left>this is a test</div>",
    5 t2 `/ m2 H. f5 |) S; J9 ^
  4.     $out, PREG_PATTERN_ORDER);  n' m$ `9 M( D7 W0 ]
  5. print $out[0][0].", ".$out[0][1]."\n";: [4 A2 ]! T* U* s9 h/ l: Q
  6. print $out[1][0].", ".$out[1][1]."\n";8 R0 e) D3 L; h" p# J7 w
  7. ?>
複製代碼
6 E# W% M! W8 m1 j' |5 ?% q
本例將输出:
  1. <b>example: </b>, <div align=left>this is a test</div>5 P) L' \( e4 l9 n! ]& t) r
  2. example: , this is a test
複製代碼

! u8 z7 C$ |# v- e6 q  C
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
' q1 L: `$ E$ q  ^7 r

# v5 \+ U! C9 s" s0 @2 J$ Z2 H  V$ s% V0 B$ l; S
PREG_SET_ORDER
对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
  1. <?php
    7 n* K7 O) R# [# I6 r# F
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",, Q% C3 ?8 h) U; _3 Q, H
  3.     "<b>example: </b><div align=left>this is a test</div>",
    3 M; W# u6 B8 r7 Q
  4.     $out, PREG_SET_ORDER);
    & ]$ f1 V- N2 E. E8 n0 R# |
  5. print $out[0][0].", ".$out[0][1]."\n";1 H2 ~( b6 c- g, }5 g6 K! A$ i4 u
  6. print $out[1][0].", ".$out[1][1]."\n";+ H5 U8 E/ `" a, S! F1 w
  7. ?>
複製代碼

/ B' u7 h& U* T% T, W& t9 P本例将输出:
  1. <b>example: </b>, example:6 w: s0 m1 d5 d7 K! ?: R& u: T
  2. <div align=left>this is a test</div>, this is a test/ x! _5 |" L4 |1 ~6 n
複製代碼

4 Y! v1 D% L  z
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE
如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。

5 Q: r. Q) R* L+ m/ x/ i% L. I% M8 U  P6 ]/ ~- S* ~/ x' \9 A( _5 O
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。

3 F+ m# v# ]' X4 o) u6 ?
例子 1. 从某文本中取得所有的电话号码
  1. <?php
    8 r1 L$ V0 g9 H" U; P
  2. preg_match_all ("/\(?  (\d{3})?  \)?  (?(1)  [\-\s] ) \d{3}-\d{4}/x",$ |7 l: U; v. v5 o, d+ F) ~' ?
  3.                 "Call 555-1212 or 1-800-555-1212 FREE", $phones);
    6 O% R2 m4 _# {
  4. ?>
複製代碼
例子 2. 搜索匹配的 HTML 标记(greedy)
  1. <?php* w) S% l  i% M) M
  2. // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
    4 X0 x0 H8 L8 G. G: n/ a
  3. // 必须匹配正则表达式本身中第二组括号内的内容,本例中( F0 T; `) P& I
  4. // 就是 ([\w]+)。因为字符串在双引号中,所以需要2 P' r( F+ G, c5 b# [' w6 r
  5. // 多加一个反斜线。0 h/ e$ X! S  n6 w" n
  6. $html = "<b>bold text</b><a href=howdy.html>click me</a>";
    # s( E; @3 ]9 i8 o

  7. . B' N1 ]3 V0 r0 F
  8. preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
    , y( r" ]. f( H9 _+ q' c

  9. # S9 A: e" {& \$ {( t
  10. for ($i=0; $i< count($matches[0]); $i++) {
    8 @( s, @% o* p' H
  11.   echo "matched: ".$matches[0][$i]."\n";
    ! D) p/ C9 F/ l  z6 h! E
  12.   echo "part 1: ".$matches[1][$i]."\n";
    : A* s5 a: k" S$ N& k1 u; P
  13.   echo "part 2: ".$matches[3][$i]."\n";- R& Q# T5 s# P
  14.   echo "part 3: ".$matches[4][$i]."\n\n";+ O) a1 ~: K/ |7 F6 ~
  15. }
    2 C, I# y% K, \. Y9 U7 g
  16. ?>
複製代碼
本例将输出:
  1. matched: <b>bold text</b>2 k. |8 ]$ `* d" z; z' u
  2. part 1: <b>
    ) Z. k* [3 P4 y' o3 g
  3. part 2: bold text
    # z' d) d, D8 y+ I2 z1 M5 C
  4. part 3: </b>
      G0 N! U8 U8 w8 e: p  W
  5. + N: X# d" B" z1 m* W1 t" s
  6. matched: <a href=howdy.html>click me</a>
    " W+ g1 C- P% d* C& u
  7. part 1: <a href=howdy.html>
    . W! O: x" Q6 v9 ~
  8. part 2: click me) |4 f7 y! U( I. L$ ^% ~
  9. part 3: </a>
複製代碼

; J* ?' ?1 O# a+ o, W
3 ^, |" [  q; A




歡迎光臨 52AV手機A片王|52AV.ONE (https://www.52av23.xyz/) Powered by Discuz! X3.2