久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      PHP正則表達(dá)式的逆向引用與子模式分析

      正則表達(dá)式一個(gè)最重要的特性就是將匹配成功的模式的某部分進(jìn)行存儲(chǔ)供以后使用這一能力。
      對(duì)一個(gè)正則表達(dá)式模式或部分模式兩邊添加圓括號(hào)()可以把這部分表達(dá)式存儲(chǔ)到一個(gè)臨時(shí)緩沖區(qū)中。

      所捕獲的每個(gè)子匹配都按照在正則表達(dá)式模式中從左至右所遇到的內(nèi)容按順序存儲(chǔ)。
      存儲(chǔ)子匹配的緩沖區(qū)編號(hào)從1開(kāi)始,連續(xù)編號(hào)至最大99個(gè)子表達(dá)式。
      每個(gè)緩沖區(qū)都可以使用’n'(或用’$n’)訪問(wèn),其中n為1至99的阿拉伯?dāng)?shù)字,用來(lái)按順序標(biāo)識(shí)特定緩沖區(qū)(子表達(dá)式)。

      例1:最簡(jiǎn)單最有用的例子是確定文字中連續(xù)出現(xiàn)兩個(gè)相同單詞的位置

      復(fù)制代碼 代碼如下:
      <?php
      $string = “Is is the cost of of gasoline going up up”;
      $pattern = “/b([a-z]+) \1b/i”; //這里的\1不能使用$1或$1
      $str = preg_replace($pattern, “\1”, $string); //這里的\1可以使用$1或$1,引用第一個(gè)子匹配
      echo $str; //效果是Is the cost of gasoline going up
      ?>

      例中的子表達(dá)式就是圓括號(hào)內(nèi)的項(xiàng)。b匹配單詞的開(kāi)始或結(jié)束。+匹配重復(fù)一次或更多次。
      該子表達(dá)式匹配的是一個(gè)或多個(gè)字母字符的單詞,即由'[a-z]+’匹配的。

      該正則表達(dá)式的第二部分是對(duì)前面所捕獲的子匹配的引用,也就是由附加表達(dá)式所匹配的第二次出現(xiàn)的單詞,用’\1’來(lái)引用第一個(gè)子匹配,第一個(gè)是轉(zhuǎn)義符。

      i是正則表達(dá)式中的修正符。i:忽略大小寫。

      例2:

      正則表達(dá)式的逆向引用($0-99或\0-99)和子模式以(/()/)開(kāi)始。
      這里$0是全部匹配模式的匹配項(xiàng)。$1是第1個(gè)子匹配,$2至$99依次是第2個(gè)至第99個(gè)子匹配。
      用$1-99后向引用子匹配時(shí),如果后面的字符是數(shù)字,要用花括號(hào)區(qū)別開(kāi)。例:${1}1 。

      函數(shù)
      mixed preg_replace ( mixed pattern, mixed replacement, mixed subject [, int limit])

      功能
      在 subject 中搜索 pattern 模式的匹配項(xiàng)并替換為 replacement。如果指定了 limit,則僅替換 limit 個(gè)匹配,如果省略 limit 或者其值為 -1,則所有的匹配項(xiàng)都會(huì)被替換。
      replacement可以包含\n形式或$n形式的逆向引用,n可以為0到99,\n表示匹配pattern第n個(gè)子模式的文本,\0表示匹配整個(gè)pattern的文本。

      子模式
      $pattern參數(shù)中被圓括號(hào)括起來(lái)的正則表達(dá)式,子模式的數(shù)目即從左到右圓括號(hào)的數(shù)目。(pattern即模式)

      例子

      復(fù)制代碼 代碼如下:
      <?php
      $time=date(“Y-m-d H:i:s”);
      $pattern = “/(d{4})-(d{2})-(d{2}) (d{2}):(d{2}):(d{2})/i”;
      $replacement = “$time格式為:$0<BR>替換后的格式為:$1年$2月$3日 $4時(shí)$5分$6秒”;
      print preg_replace($pattern, $replacement, $time);
      ?>

      輸出:
      $time格式為:2011-07-25 17:59:26
      替換后的格式為:2011年07月25日 17時(shí)59分26秒

      附正則表達(dá)式符號(hào)對(duì)照表

      字符 描述
      將下一個(gè)字符標(biāo)記為一個(gè)特殊字符、或一個(gè)原義字符、或一個(gè) 向后引用、或一個(gè)八進(jìn)制轉(zhuǎn)義符。例如,’n’ 匹配字符 “n”。’n’ 匹配一個(gè)換行符。序列 ‘\’ 匹配 “” 而 “(” 則匹配 “(“。
      ^ 匹配輸入字符串的開(kāi)始位置。如果設(shè)置了 RegExp 對(duì)象的 Multiline 屬性,^ 也匹配 ‘n’ 或 ‘r’ 之后的位置。
      $ 匹配輸入字符串的結(jié)束位置。如果設(shè)置了RegExp 對(duì)象的 Multiline 屬性,$ 也匹配 ‘n’ 或 ‘r’ 之前的位置。
      * 匹配前面的子表達(dá)式零次或多次。例如,zo* 能匹配 “z” 以及 “zoo”。* 等價(jià)于{0,}。
      + 匹配前面的子表達(dá)式一次或多次。例如,’zo+’ 能匹配 “zo” 以及 “zoo”,但不能匹配 “z”。+ 等價(jià)于 {1,}。
      ? 匹配前面的子表達(dá)式零次或一次。例如,”do(es)?” 可以匹配 “do” 或 “does” 中的”do” 。? 等價(jià)于 {0,1}。
      {n} n 是一個(gè)非負(fù)整數(shù)。匹配確定的 n 次。例如,’o{2}’ 不能匹配 “Bob” 中的 ‘o’,但是能匹配 “food” 中的兩個(gè) o。
      {n,} n 是一個(gè)非負(fù)整數(shù)。至少匹配n 次。例如,’o{2,}’ 不能匹配 “Bob” 中的 ‘o’,但能匹配 “foooood” 中的所有 o。’o{1,}’ 等價(jià)于 ‘o+’。’o{0,}’ 則等價(jià)于 ‘o*’。
      {n,m} m 和 n 均為非負(fù)整數(shù),其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,”o{1,3}” 將匹配 “fooooood” 中的前三個(gè) o。’o{0,1}’ 等價(jià)于 ‘o?’。請(qǐng)注意在逗號(hào)和兩個(gè)數(shù)之間不能有空格。
      ? 當(dāng) 該字符緊跟在任何一個(gè)其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面時(shí),匹配模式是非貪婪的。非貪婪模式盡可能少的匹配所搜索的字符串,而默認(rèn)的貪婪模式則盡可能多的匹配所搜索的字符串。例如,對(duì)于字符串 “oooo”,’o+?’ 將匹配單個(gè) “o”,而 ‘o+’ 將匹配所有 ‘o’。
      . 匹配除 “n” 之外的任何單個(gè)字符。要匹配包括 ‘n’ 在內(nèi)的任何字符,請(qǐng)使用象 ‘[.n]’ 的模式。
      (pattern) 匹配 pattern 并獲取這一匹配。所獲取的匹配可以從產(chǎn)生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中則使用 $0…$9 屬性。要匹配圓括號(hào)字符,請(qǐng)使用 ‘(‘ 或 ‘)’。
      (?:pattern) 匹 配 pattern 但不獲取匹配結(jié)果,也就是說(shuō)這是一個(gè)非獲取匹配,不進(jìn)行存儲(chǔ)供以后使用。這在使用 “或” 字符 (|) 來(lái)組合一個(gè)模式的各個(gè)部分是很有用。例如, ‘industr(?:y|ies) 就是一個(gè)比 ‘industry|industries’ 更簡(jiǎn)略的表達(dá)式。
      (?=pattern) 正 向預(yù)查,在任何匹配 pattern 的字符串開(kāi)始處匹配查找字符串。這是一個(gè)非獲取匹配,也就是說(shuō),該匹配不需要獲取供以后使用。例如,’Windows (?=95|98|NT|2000)’ 能匹配 “Windows 2000” 中的 “Windows” ,但不能匹配 “Windows 3.1” 中的 “Windows”。預(yù)查不消耗字符,也就是說(shuō),在一個(gè)匹配發(fā)生后,在最后一次匹配之后立即開(kāi)始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開(kāi)始。
      (?!pattern) 負(fù) 向預(yù)查,在任何不匹配 pattern 的字符串開(kāi)始處匹配查找字符串。這是一個(gè)非獲取匹配,也就是說(shuō),該匹配不需要獲取供以后使用。例如’Windows (?!95|98|NT|2000)’ 能匹配 “Windows 3.1” 中的 “Windows”,但不能匹配 “Windows 2000” 中的 “Windows”。預(yù)查不消耗字符,也就是說(shuō),在一個(gè)匹配發(fā)生后,在最后一次匹配之后立即開(kāi)始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開(kāi)始
      x|y 匹配 x 或 y。例如,’z|food’ 能匹配 “z” 或 “food”。'(z|f)ood’ 則匹配 “zood” 或 “food”。
      [xyz] 字符集合。匹配所包含的任意一個(gè)字符。例如, ‘[abc]’ 可以匹配 “plain” 中的 ‘a’。
      [^xyz] 負(fù)值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以匹配 “plain” 中的’p’。
      [a-z] 字符范圍。匹配指定范圍內(nèi)的任意字符。例如,'[a-z]’ 可以匹配 ‘a’ 到 ‘z’ 范圍內(nèi)的任意小寫字母字符。
      [^a-z] 負(fù)值字符范圍。匹配任何不在指定范圍內(nèi)的任意字符。例如,'[^a-z]’ 可以匹配任何不在 ‘a’ 到 ‘z’ 范圍內(nèi)的任意字符。
      b 匹配一個(gè)單詞邊界,也就是指單詞和空格間的位置。例如, ‘erb’ 可以匹配”never” 中的 ‘er’,但不能匹配 “verb” 中的 ‘er’。
      B 匹配非單詞邊界。’erB’ 能匹配 “verb” 中的 ‘er’,但不能匹配 “never” 中的 ‘er’。
      cx 匹配由 x 指明的控制字符。例如, cM 匹配一個(gè) Control-M 或回車符。x 的值必須為 A-Z 或 a-z 之一。否則,將 c 視為一個(gè)原義的 ‘c’ 字符。
      d 匹配一個(gè)數(shù)字字符。等價(jià)于 [0-9]。
      D 匹配一個(gè)非數(shù)字字符。等價(jià)于 [^0-9]。
      f 匹配一個(gè)換頁(yè)符。等價(jià)于 x0c 和 cL。
      n 匹配一個(gè)換行符。等價(jià)于 x0a 和 cJ。
      r 匹配一個(gè)回車符。等價(jià)于 x0d 和 cM。
      s 匹配任何空白字符,包括空格、制表符、換頁(yè)符等等。等價(jià)于 [ fnrtv]。
      S 匹配任何非空白字符。等價(jià)于 [^ fnrtv]。
      t 匹配一個(gè)制表符。等價(jià)于 x09 和 cI。
      v 匹配一個(gè)垂直制表符。等價(jià)于 x0b 和 cK。
      w 匹配包括下劃線的任何單詞字符。等價(jià)于'[A-Za-z0-9_]’。
      W 匹配任何非單詞字符。等價(jià)于 ‘[^A-Za-z0-9_]’。
      xn 匹配 n,其中 n 為十六進(jìn)制轉(zhuǎn)義值。十六進(jìn)制轉(zhuǎn)義值必須為確定的兩個(gè)數(shù)字長(zhǎng)。例如,’x41′ 匹配 “A”。’x041′ 則等價(jià)于 ‘x04’ & “1”。正則表達(dá)式中可以使用 ASCII 編碼。.
      num 匹配 num,其中 num 是一個(gè)正整數(shù)。對(duì)所獲取的匹配的引用。例如,'(.)1′ 匹配兩個(gè)連續(xù)的相同字符。
      n 標(biāo)識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。如果 n 之前至少 n 個(gè)獲取的子表達(dá)式,則 n 為向后引用。否則,如果 n 為八進(jìn)制數(shù)字 (0-7),則 n 為一個(gè)八進(jìn)制轉(zhuǎn)義值。
      nm 標(biāo) 識(shí)一個(gè)八進(jìn)制轉(zhuǎn)義值或一個(gè)向后引用。如果 nm 之前至少有 nm 個(gè)獲得子表達(dá)式,則 nm 為向后引用。如果 nm 之前至少有 n 個(gè)獲取,則 n 為一個(gè)后跟文字 m 的向后引用。如果前面的條件都不滿足,若 n 和 m 均為八進(jìn)制數(shù)字 (0-7),則 nm 將匹配八進(jìn)制轉(zhuǎn)義值 nm。
      nml 如果 n 為八進(jìn)制數(shù)字 (0-3),且 m 和 l 均為八進(jìn)制數(shù)字 (0-7),則匹配八進(jìn)制轉(zhuǎn)義值 nml。
      un 匹配 n,其中 n 是一個(gè)用四個(gè)十六進(jìn)制數(shù)字表示的 Unicode 字符。例如, u00A9 匹配版權(quán)符號(hào) (?)。
      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)