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] )
2 W. Q. |! S# ?" r4 U) p
" }" {0 t! j. ^; E/ K+ r" f

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

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

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


) H' H3 _- _1 f- t0 MPREG_PATTERN_ORDER
對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
  1. <?php3 V7 ^3 M0 }( b# Q1 y6 B
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
    - ]8 G+ ]3 _' p7 d  L5 G, P- |
  3.     "<b>example: </b><div align=left>this is a test</div>"," o- x. ^, F8 @
  4.     $out, PREG_PATTERN_ORDER);
    6 \: h& R6 q. h+ o. C
  5. print $out[0][0].", ".$out[0][1]."\n";, U: O# m6 p  f3 N6 D
  6. print $out[1][0].", ".$out[1][1]."\n";
    + ^' ^/ j: Q  C( K& h$ N! V
  7. ?>
複製代碼
4 d$ J2 S9 f9 C& K4 D
本例將输出:
  1. <b>example: </b>, <div align=left>this is a test</div>0 T! q  K0 S( D2 x8 z4 V( u! O
  2. example: , this is a test
複製代碼

; Z( r  v" ?7 E& E& s
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。

5 k" L" V7 X  P# F; j3 C- I" Z( H8 X% Y. I3 ?
- C2 I  ?/ S2 o, a
PREG_SET_ORDER
对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
  1. <?php7 B* o, |: I6 x; s/ ~8 f
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",
    1 _8 N+ c) L* l
  3.     "<b>example: </b><div align=left>this is a test</div>",* s0 V, C, D+ P
  4.     $out, PREG_SET_ORDER);
    ) k5 K$ m0 K& V, N) r
  5. print $out[0][0].", ".$out[0][1]."\n";
    2 q5 F3 c. v4 H! ^$ t
  6. print $out[1][0].", ".$out[1][1]."\n";$ {! q7 C/ C! t+ K0 z* M. l
  7. ?>
複製代碼
, _( C% A- x  ]3 |) z' {
本例将输出:
  1. <b>example: </b>, example:
    ; P3 n( l+ A8 t  F/ s2 P
  2. <div align=left>this is a test</div>, this is a test
    8 e5 [  w+ R+ H) T! ?) B0 v! E
複製代碼

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

6 l" [; k: F2 w5 o6 x4 j2 ~# `. o' @! d6 c* s' y" M
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。

/ t( s" a2 h- c3 r
例子 1. 从某文本中取得所有的电话号码
  1. <?php
    ) Z$ a3 j3 s0 O  D: H
  2. preg_match_all ("/\(?  (\d{3})?  \)?  (?(1)  [\-\s] ) \d{3}-\d{4}/x",
    4 a( t% A! X: P- e
  3.                 "Call 555-1212 or 1-800-555-1212 FREE", $phones);" k2 c7 `! i& W2 F' S, A
  4. ?>
複製代碼
例子 2. 搜索匹配的 HTML 标记(greedy)
  1. <?php
    6 [  H+ q  \; v) ]% F
  2. // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是
    ! p3 H% z* B) w3 B  I) I
  3. // 必须匹配正则表达式本身中第二组括号内的内容,本例中
    ; |) f  ~+ T- [( J5 D8 r
  4. // 就是 ([\w]+)。因为字符串在双引号中,所以需要5 {# V  z  i2 }4 E5 |
  5. // 多加一个反斜线。; i. s" R4 G* g# }" P
  6. $html = "<b>bold text</b><a href=howdy.html>click me</a>";
    9 N( y! \/ K4 Z  U

  7. ; _$ r" Y- I% |) ^9 T7 w% T
  8. preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);
    9 h% C" g4 y; K

  9. * m2 w; }6 B1 `5 Q1 }1 r" V1 ]
  10. for ($i=0; $i< count($matches[0]); $i++) {
    7 Q" \& P" O# l  F  A1 f
  11.   echo "matched: ".$matches[0][$i]."\n";
    " ]! g* q. T4 e% N
  12.   echo "part 1: ".$matches[1][$i]."\n";  N! A9 y% A& u" d; `
  13.   echo "part 2: ".$matches[3][$i]."\n";& t* Y6 x1 R9 C! W; a
  14.   echo "part 3: ".$matches[4][$i]."\n\n";) M( p6 W6 G) _& y( M2 m
  15. }! U- N4 L# l. L* V! G+ @5 G
  16. ?>
複製代碼
本例将输出:
  1. matched: <b>bold text</b>" `: Q" _$ k( k
  2. part 1: <b>
    8 ~6 _7 B' K6 N, k+ O1 Y
  3. part 2: bold text$ E' C$ H) X8 U4 H9 m" y6 u) X& y
  4. part 3: </b>
    " J/ m) D) i( a' Y' q
  5. / I: i/ V  E2 G9 k, x
  6. matched: <a href=howdy.html>click me</a>
    ) \& F+ Z9 ?7 d$ n4 P
  7. part 1: <a href=howdy.html>6 K5 ]8 O- }3 Y/ N
  8. part 2: click me0 S1 j* Y& e* K! s, D  j6 l
  9. part 3: </a>
複製代碼

1 [% D6 J& C2 [. A% k0 {! Y* c
9 f3 K2 T/ R: G" n: X




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