久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放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á)式函數(shù)庫(kù)(兩套)

      在PHP中有兩套正則表達(dá)式函數(shù)庫(kù),兩者功能相似,只是執(zhí)行效率略有差異:
      一套是由PCRE(Perl Compatible Regular Expression)庫(kù)提供的。使用“preg_”為前綴命名的函數(shù);
      一套由POSIX(Portable Operating System Interface of Unix )擴(kuò)展提供的(PHP默認(rèn))。使用以“ereg_”為前綴命名的函數(shù);
      PHP中,正則表達(dá)式有三個(gè)作用:
      匹配,也常常用于從字符串中析取信息。
      用新文本代替匹配文本。
      將一個(gè)字符串拆分為一組更小的信息塊。

      一個(gè)正則表達(dá)式中至少包含一個(gè)原子。
      原子(普通字符,如英文字符)
      元字符(有特殊功用的字符)
      模式修正字符(對(duì)正則表達(dá)式語(yǔ)義的修正)

      原子(Atom)
      單個(gè)字符、數(shù)字,如a~z,A~Z,0~9。
      模式單元,如(ABC)可以理解為由多個(gè)原子組成的大的原子。
      原子表,如 [ABC]。
      重新使用的模式單元,如:\1
      普通轉(zhuǎn)義字符,如:d, D, w
      轉(zhuǎn)義元字符,如:*,.

      POSIX正則表達(dá)式
      POSIX正則表達(dá)式全稱為Portable Operating System Interface of Unix,意為UNIX可移植操作系實(shí)現(xiàn)接口。

      構(gòu)造POSIX正則表達(dá)式的方法和創(chuàng)建數(shù)學(xué)表達(dá)式的方法一樣,也就是用多種元字符與操作符將小的表達(dá)式結(jié)合在一起來創(chuàng)建更大的表達(dá)式。

      元字符(Meta-character)
      元字符是用于構(gòu)造規(guī)則表達(dá)式的具有特殊含義的字符。如果要在正則表達(dá)式中包含元字符本身,必須在其前加上””進(jìn)行轉(zhuǎn)義
      元字符 說明
      * 0次、1次或多次匹配其前的原子
      + 1次或多次匹配其前的原子
      ? 0次或1次匹配其前的原子
      | 匹配兩個(gè)或多個(gè)選擇 列如 [1-9]|[a-b]|[A-Z] 與其中任何匹配為ture
      ^ 匹配字符串串首的原子 例如 abscd===^afdgfgf 相匹配
      $ 匹配字符串串尾的原子 例如 dasdsv===v$
      [] 匹配方括號(hào)中的任一原子 例如 s===[dsadas]
      [^] 匹配除方括號(hào)中的原子外的任何字符 例如 aaaaa===[dddd]
      {m} 表示其前原子恰好出現(xiàn)m次
      {m,n} 表示其前原子至少出現(xiàn)m次,至少出現(xiàn)n次(n>m)
      {m,} 表示其前原子出現(xiàn)不少于m次
      () 整體表示一個(gè)原子
      . 匹配除換行之外的任何一個(gè)字符

      ^ $ 這兩個(gè)原字符在一起稱為定界
      abd===^abc$ 只有這樣才匹配

      模式匹配的順序
      順序 元字符 說明
      1 () 模式單元
      2 ?* +{} 重復(fù)匹配
      3 ^$ 邊界限制
      4 | 模式選擇

      POSIX正則表達(dá)式函數(shù)
      ereg()和eregi()
      ereg_replace()和eregi_replace()
      split()和spliti()

      ereg()和eregi()ereg()字符串匹配函數(shù),eregi()是ereg()函數(shù)的忽略大小的版本
      語(yǔ)法格式:if (!ereg(‘^[^./][^/]*$’, $userfile))//不匹配格式輸出die
      {
      die(‘這是一個(gè)非法的文件名!’);
      }

      ereg_replace()和eregi_replace(忽略大小寫)替換
      string eregi_replace (“正則表達(dá)式”,“目標(biāo)替換字符”,“替換目標(biāo)”)
      語(yǔ)法格式:$string = “This is a test”;
      echo str_replace(” is”, ” was”, $string);
      echo ereg_replace(“( )is”, “\1was”, $string);\1 為繼承第一個(gè)整體
      echo ereg_replace(“(( )is)”, “\2was”, $string);\2繼承第二個(gè)整體

      split()和spliti(忽略大小寫)用正則表達(dá)式將字符串分割到數(shù)組中
      list:給數(shù)組中的值賦予一些變量
      語(yǔ)法格式:$date = “04/30/1973”;
      list($month, $day, $year) = split (‘[/.-]’, $date);//列出三個(gè)變數(shù)對(duì)應(yīng)格式//以什么形式拆分 拆分誰(shuí)
      echo “Month: $month; Day: $day; Year: $year<br />
      “;
      輸出結(jié)果Month: 04; Day: 30; Year: 1973

      多行匹配

      $rows = file(‘php.ini’); //將php.ini文件讀到數(shù)組中

      //循環(huán)便歷
      foreach($rows as $line)
      {
      if(trim($line))
      {
      //將匹配成功的參數(shù)寫入數(shù)組中
      if(eregi(“^([a-z0-9_.]*) *=(.*)”, $line, $matches)) //循環(huán)進(jìn)行多行匹配
      {
      $options[$matches[1]] = trim($matches[2]);
      }
      unset($matches);
      }
      }

      //輸出參數(shù)結(jié)果
      print_r($options);

      PCRE正則表達(dá)式
      PCRE全稱為Perl Compatible Regular Expression,意思是Perl兼容正則表達(dá)式。
      在PCRE中,通常將模式表達(dá)式(即正則表達(dá)式)包含在兩個(gè)反斜線“/”之間,如“/apple/”。

      元字符(Meta-character)
      元字符 說明
      A 匹配字符串串首的原子
      Z 匹配字符串串尾的原子
      b 匹配單詞的邊界 /bis/ 匹配頭為is的字符串 /isb/ 匹配尾為is的字符串 /bisb/ 定界
      B 匹配除單詞邊界之外的任意字符 /Bis/ 匹配單詞“This”中的“is”

      d 匹配一個(gè)數(shù)字;等價(jià)于[0-9]
      D 匹配除數(shù)字以外任何一個(gè)字符;等價(jià)于[^0-9]
      w 匹配一個(gè)英文字母、數(shù)字或下劃線;等價(jià)于[0-9a-zA-Z_]
      W 匹配除英文字母、數(shù)字和下劃線以外任何一個(gè)字符;等價(jià)于[^0-9a-zA-Z_]
      s 匹配一個(gè)空白字符;等價(jià)于[f
      tv]
      S 匹配除空白字符以外任何一個(gè)字符;等價(jià)于[^f
      tv]
      f 匹配一個(gè)換頁(yè)符等價(jià)于 x0c 或 cL
      匹配一個(gè)換行符;等價(jià)于 x0a 或 cJ
      匹配一個(gè)回車符等價(jià)于x0d 或 cM
      t 匹配一個(gè)制表符;等價(jià)于 x09或cl
      v 匹配一個(gè)垂直制表符;等價(jià)于x0b或ck
      oNN 匹配一個(gè)八進(jìn)制數(shù)字
      xNN 匹配一個(gè)十六進(jìn)制數(shù)字
      cC 匹配一個(gè)控制字符

      模式修正符(Pattern Modifiers)
      i -可同時(shí)匹配大小寫字母
      M -將字符串視為多行
      S -將字符串視為單行,換行符做普通字符看待,使“.”匹配任何字符
      X -模式中的空白忽略不計(jì)
      U -匹配到最近的字符串
      e -將替換的字符串作為表達(dá)使用
      格式:/apple/i匹配“apple”或“Apple”等,忽略大小寫。 /i

      PCRE的模式單元
      //1 提取第一位的屬性
      /^d{2}([W])d{2}\1d{4}$匹配“12-31-2006”、“09/27/1996”、“86 01 4321”等字符串。但上述正則表達(dá)式不匹配“12/34-5678”的格式。這是因?yàn)槟J健癧W]”的結(jié)果“/”已經(jīng)被存儲(chǔ)。下個(gè)位置“1”引用時(shí),其匹配模式也是字符“/”。

      當(dāng)不需要存儲(chǔ)匹配結(jié)果時(shí)使用非存儲(chǔ)模式單元“(?:)”
      例如/(?:a|b|c)(D|E|F)\1g/ 將匹配“aEEg”。在一些正則表達(dá)式中,使用非存儲(chǔ)模式單元是必要的。否則,需要改變其后引用的順序。上例還可以寫成/(a|b|c)(C|E|F)2g/。

      PCRE正則表達(dá)式函數(shù)
      preg_match()和preg_match_all()
      preg_quote()
      preg_split()
      preg_grep()
      preg_replace()

      preg_match()和preg_match_all()正則表達(dá)式的匹配
      語(yǔ)法格式:if (preg_match (“/php/i”, “PHP is the web scripting language of choice.”)) {
      print “A match was found.”;
      } else {
      print “A match was not found.”;
      }

      preg_quote()轉(zhuǎn)義正則表達(dá)式字符
      語(yǔ)法格式:$keywords = “$40 for a g3/400”;
      $keywords = preg_quote ($keywords, “/”);//轉(zhuǎn)義誰(shuí) /轉(zhuǎn)義符號(hào)
      echo $keywords;

      preg_split()用正則表達(dá)式分割字符串
      preg_split()本函數(shù)與split函數(shù)功能一致。
      語(yǔ)法格式:$keywords = preg_split (“/[s,]+/”, “hypertext language, programming”);
      print_r($keywords);

      preg_grep()返回與模式匹配的數(shù)組單元
      語(yǔ)法格式:$fl_array = preg_grep (“/^(d+)?.d+$/”, $array);

      preg_replace()執(zhí)行正則表達(dá)式的搜索和替換
      語(yǔ)法格式:

      復(fù)制代碼 代碼如下:
      $string = “April 15, 2003”;
      $pattern = “/(w+) (d+), (d+)/i”;
      $replacement = “${1}1,$3”;
      print preg_replace($pattern, $replacement, $string);

      preg_match_all()進(jìn)行全局正則表達(dá)式匹配
      語(yǔ)法格式:

      復(fù)制代碼 代碼如下:
      preg_match_all (“|<[^>]+>(.*)</[^>]+>|U”,
      “<b>example: </b><div align=left>this is a test</div>”,
      $out, PREG_PATTERN_ORDER);
      print $out[0][0].”, “.$out[0][1].”
      “;
      print $out[1][0].”, “.$out[1][1].”
      “;

      輸出結(jié)果:<b>example: </b>, <div align=left>this is a test</div> example: , this is a test

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)