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] )
/ B7 s$ R- ?0 v7 l: i6 S9 H# E0 C( N
" t  i2 o+ z: J, Z

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

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

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

0 P5 f- @5 w) p) y9 e. E
PREG_PATTERN_ORDER
對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
  1. <?php4 ?% T$ g" g  J$ H
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",/ x  j) Q7 d6 c, H  }+ m) V
  3.     "<b>example: </b><div align=left>this is a test</div>",
    , H5 I9 t/ R& {! O
  4.     $out, PREG_PATTERN_ORDER);
    " t9 [( L  P1 v) L' V0 [; V6 k
  5. print $out[0][0].", ".$out[0][1]."\n";8 M0 B2 x- K, w8 w6 T
  6. print $out[1][0].", ".$out[1][1]."\n";5 ~; [. R8 f- Y& y# J: u; C
  7. ?>
複製代碼
3 M! U5 J( V6 c/ H  e4 \; a
本例將输出:
  1. <b>example: </b>, <div align=left>this is a test</div>
    ; V9 ]: Z1 R. y' R
  2. example: , this is a test
複製代碼

) v' @0 W; ]1 l+ X5 e( O
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。

" c+ _5 I, Y% [9 [
3 e2 W( _+ F2 t9 L+ ?" ?" S( s: f. b
PREG_SET_ORDER
对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
  1. <?php
    . D) x+ Z/ e4 s' o
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
    ' M. G& o6 H- U$ I) G* ]
  3.     "<b>example: </b><div align=left>this is a test</div>",
    1 Y( ?" e$ k0 f4 R
  4.     $out, PREG_SET_ORDER);
    ) q. A: r0 A& Q7 v( I
  5. print $out[0][0].", ".$out[0][1]."\n";, o+ k# h8 T6 |: Z% t' r# j' Z2 ^) `
  6. print $out[1][0].", ".$out[1][1]."\n";1 V) ^. B( R0 {+ c% S5 Q7 }* C
  7. ?>
複製代碼

4 @9 U# y3 B& `  @6 w  A本例将输出:
  1. <b>example: </b>, example:! ?* F3 ]2 k2 n: ^' n! b
  2. <div align=left>this is a test</div>, this is a test
    - I# y9 c  l5 F- o; B4 V
複製代碼

; m" p1 U: K6 l' ?3 @! k! `9 l
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE
如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。
: \! @6 I; s* L: x& O; ^9 [

5 B4 g2 T0 D- s; U4 M
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。

3 V) S% Y; `% j5 d# c. L9 M8 ^
例子 1. 从某文本中取得所有的电话号码
  1. <?php- k/ a+ Y6 j) _' V* |3 y" E
  2. preg_match_all ("/\(?  (\d{3})?  \)?  (?(1)  [\-\s] ) \d{3}-\d{4}/x",2 g, a" y- R$ o5 y" ?. l
  3.                 "Call 555-1212 or 1-800-555-1212 FREE", $phones);+ M: [- L1 ^) K" ~# S
  4. ?>
複製代碼
例子 2. 搜索匹配的 HTML 标记(greedy)
  1. <?php  |! ]. p- v5 R7 B$ s( D
  2. // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是- g  _; B- w% Q
  3. // 必须匹配正则表达式本身中第二组括号内的内容,本例中0 F# B, }2 e! D/ k1 U# h* w, g
  4. // 就是 ([\w]+)。因为字符串在双引号中,所以需要' x$ [& Z! F$ M' D$ H
  5. // 多加一个反斜线。
    9 R, r4 j. g5 x0 N% m! c8 D
  6. $html = "<b>bold text</b><a href=howdy.html>click me</a>";2 m8 c& D5 A) M( `9 Q

  7. * U) q+ p! \: Z
  8. preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
    2 e& G, t/ C! m

  9.   }9 x& c2 T, E; S) O! O
  10. for ($i=0; $i< count($matches[0]); $i++) {; l7 j4 z+ U& Z! |' E6 ?, v; X( |& u
  11.   echo "matched: ".$matches[0][$i]."\n";6 E% B; j: M4 K3 ~" R
  12.   echo "part 1: ".$matches[1][$i]."\n";/ K3 Z2 E2 \( m
  13.   echo "part 2: ".$matches[3][$i]."\n";( C3 S( w- e/ F% P+ _
  14.   echo "part 3: ".$matches[4][$i]."\n\n";
    % c; x9 I; o  E
  15. }
    : q# g$ v" l" c: G# w) U
  16. ?>
複製代碼
本例将输出:
  1. matched: <b>bold text</b>1 [. X/ F' k& O# A' k
  2. part 1: <b>  j( C" c0 Y6 W. N+ m9 [- Z
  3. part 2: bold text
    5 `3 X2 t  ^1 ^
  4. part 3: </b>
    3 y1 `4 N! b. u

  5. 6 Y- q, ?) j0 @6 i7 z
  6. matched: <a href=howdy.html>click me</a>
    ' `* L" E/ x. w, c8 O  F
  7. part 1: <a href=howdy.html>, }  D% U+ F7 @: R: `2 l
  8. part 2: click me* c6 J, e" t6 o/ Y: M1 h
  9. part 3: </a>
複製代碼

, P& |1 q: e  g; s
' Y$ ]5 q5 o6 Q1 H- C- Y1 }




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