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] )5 x) |" G: E& z  [: C1 e& T

, D( z. h  v7 y7 l: X* J

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

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

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


3 e7 |# H9 n  r+ |4 q+ A% cPREG_PATTERN_ORDER
對結果排序使 $matches[0] 為全部模式匹配的字串,$matches[1]為第一個括号中的子模式所匹配的字串,以此類推。
  1. <?php
    2 ^4 z9 @0 `0 ^  R; c) L
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",7 U. c% w; F* K; L  ]0 l
  3.     "<b>example: </b><div align=left>this is a test</div>",0 `* ?( w8 M/ u4 u3 ^- R; G
  4.     $out, PREG_PATTERN_ORDER);
    9 }1 H. g9 ]& a6 G9 d/ @
  5. print $out[0][0].", ".$out[0][1]."\n";  J8 U1 f- q/ S
  6. print $out[1][0].", ".$out[1][1]."\n";
      E+ ^3 `, K, [' U  b2 B
  7. ?>
複製代碼

1 g/ E/ I& N1 y6 A, Y) j本例將输出:
  1. <b>example: </b>, <div align=left>this is a test</div>4 P7 [8 s9 i  e0 L; o: I5 }, m
  2. example: , this is a test
複製代碼
  q, G+ I3 \2 e
因此,$out[0] 包含匹配整个模式的字串,$out[1] 包含一對HTML 標記之間的字串。
4 h  B, J8 ^. @0 u' p: i; {

5 l* K) N* T6 C9 W- s, F  R- n# b7 X4 ?' y" M4 N! M" a
PREG_SET_ORDER
对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推。
  1. <?php
    # j% G- q0 L" I* X3 c4 }
  2. preg_match_all ("|<[^>]+>(.*)</[^>]+>|U",% {0 g: z9 F7 u
  3.     "<b>example: </b><div align=left>this is a test</div>",2 f9 l+ \; d% h0 v
  4.     $out, PREG_SET_ORDER);
    4 c2 Q7 n3 q6 R) F( W2 C
  5. print $out[0][0].", ".$out[0][1]."\n";
    6 I& d, e/ a6 y; G
  6. print $out[1][0].", ".$out[1][1]."\n";
    ' @; `" i4 z3 \
  7. ?>
複製代碼

3 R3 a- z6 q  y2 r) {本例将输出:
  1. <b>example: </b>, example:8 f9 _$ O! m1 d  m
  2. <div align=left>this is a test</div>, this is a test
    4 U1 z. @3 D0 M/ v  n8 T
複製代碼
+ h' G' T# s: d1 Q
本例中,$matches[0] 是第一组匹配结果,$matches[0][0] 包含匹配整个模式的文本,$matches[0][1] 包含匹配第一个子模式的文本,以此类推。同样,$matches[1] 是第二组匹配结果,等等。
PREG_OFFSET_CAPTURE
如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其在 subject 中的偏移量。本标记自 PHP 4.3.0 起可用。

2 Y0 i! ^. ^* P# U4 E# |: c7 |
& S( l$ I* r7 d, H, X" `% v- P; Z
如果没有给出标记,则假定为 PREG_PATTERN_ORDER。
返回整个模式匹配的次数(可能为零),如果出错返回 FALSE。

! k2 _6 Z' t& s" T
例子 1. 从某文本中取得所有的电话号码
  1. <?php  x( l- p  D* e0 B# U6 y5 ]
  2. preg_match_all ("/\(?  (\d{3})?  \)?  (?(1)  [\-\s] ) \d{3}-\d{4}/x",8 f9 U5 Q" \4 W+ @
  3.                 "Call 555-1212 or 1-800-555-1212 FREE", $phones);
    6 \& a2 Y" \/ E& s/ G8 r
  4. ?>
複製代碼
例子 2. 搜索匹配的 HTML 标记(greedy)
  1. <?php
    * o& v+ P0 l" b) {- l: m
  2. // \\2 是一个逆向引用的例子,其在 PCRE 中的含义是. A. C5 [0 K; _4 p
  3. // 必须匹配正则表达式本身中第二组括号内的内容,本例中
    $ D2 M. c3 z, V5 g" N
  4. // 就是 ([\w]+)。因为字符串在双引号中,所以需要
    3 A5 ^4 `" p8 w; |
  5. // 多加一个反斜线。) p) Q7 t- e& o6 Y$ s% ^
  6. $html = "<b>bold text</b><a href=howdy.html>click me</a>";
    " F" j" e; B$ a4 N& t% n
  7. 2 x+ L2 n* x8 a7 @4 _  T7 u( [
  8. preg_match_all ("/(<([\w]+)[^>]*>)(.*)(<\/\\2>)/", $html, $matches);2 v, q* }6 {1 ]
  9. # W% \+ v, {' @) R# Y
  10. for ($i=0; $i< count($matches[0]); $i++) {
    % _: h. |4 j5 n3 a" f5 ?9 O
  11.   echo "matched: ".$matches[0][$i]."\n";. g) g! g2 ^$ d  r3 s
  12.   echo "part 1: ".$matches[1][$i]."\n";
    ' h8 l* Y! B, Z
  13.   echo "part 2: ".$matches[3][$i]."\n";
    3 g/ ^) Y2 [  ^/ z" E# @/ V
  14.   echo "part 3: ".$matches[4][$i]."\n\n";2 n- X7 F& S# u8 N* x; W
  15. }/ V8 n  u% |3 M6 w1 q( b# x
  16. ?>
複製代碼
本例将输出:
  1. matched: <b>bold text</b>9 k2 q; h' |' u' R. {
  2. part 1: <b>! n; M4 r+ T# h4 V% ]
  3. part 2: bold text
    2 T/ V" v6 l1 |& x
  4. part 3: </b>+ \4 J  F, N3 i6 Y! P

  5. 0 n  r: P" M6 e4 S# l8 K
  6. matched: <a href=howdy.html>click me</a>
    : P$ f; U/ b( I/ p! ^
  7. part 1: <a href=howdy.html>
    9 `' V. d1 p% `( |
  8. part 2: click me
    & j, D0 J; ?% d- v" v& I" m
  9. part 3: </a>
複製代碼
: k3 E  x& }$ O% s# ?
3 Y1 Z0 Q7 u# S2 k, ?8 j$ f





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