日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
正則表達式之正則處理函數(shù)

前面我們已經(jīng)學(xué)習(xí)了正則表達式的基礎(chǔ)語法,包括了定界符、原子、元字符和模式修正 符。實際上正則表達式想要起作用的話,就必須借用正則表達式處理函數(shù)。本節(jié)我們就來介紹一下PHP中基于perl的正則表達式處理函數(shù),主要包含了分割, 匹配,查找,替換等等處理操作,依舊是配合示例講解,讓我們開始吧。

和正則表達式一樣,正則表達式處理函數(shù)不能夠獨立使用,而這必須相結(jié)合,才能夠完成特定的功能。在前面我們也說過,基于perl的正則表達式要快于POXIS正則表達式處理函數(shù),所以我們只介紹以preg開頭的基于perl的正則表達式。注意:在能偶使用字符串函數(shù)處理的時候,就不要使用正則表達式來處理字符串,因為字符串處理函數(shù)更快。

下面我們來看一些常用的正則表達式處理函數(shù)。

1,preg_match()函數(shù)。

函數(shù)preg_match()執(zhí)行一個正則表達式匹配,其定義如下:

 
 
 
  1. int preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]]) 

實際上就是搜索subject中匹配pattern的部分, 以保存在數(shù)組matches中.請看示例:

 
 
 
  1.  
  2.      $pattern = '/.*?<\/b>/';    
  3.      $string = 'welcome to phpfunsdsadsadas';    
  4.      if (preg_match($pattern, $string, $arr)) {    
  5.          echo "正則表達式{$pattern}和字符串{$string}匹配成功
    ";    
  6.          print_r($arr);    
  7.      } else {    
  8.          echo "正則表達式{$pattern}和字符串{$string}匹配失敗";    
  9.      }    
  10.  ?>   
  11.  

2,preg_match_all()函數(shù)。

函數(shù)preg_match_all()函數(shù)執(zhí)行一個全局正則表達式匹配,其定義和preg_match()函數(shù)一致,只不過匹配了全部結(jié)果。請看示例:

 
 
 
  1.      $pattern = '/.*?<\/b>/';    
  2.      $string = 'welcome to phpfunsdsadsadas';    
  3.      if (preg_match_all($pattern, $string, $arr)) {    
  4.          echo "正則表達式{$pattern}和字符串{$string}匹配成功
    ";    
  5.          print_r($arr);    
  6.      } else {    
  7.          echo "正則表達式{$pattern}和字符串{$string}匹配失敗";    
  8.      }    
  9.  ?>   
  10.  

依舊是上面的示例(只換了正則處理函數(shù)為preg_match_all()),但是匹配的結(jié)果數(shù)組內(nèi)容不一樣了。

3, preg_replace()函數(shù)

函數(shù)preg_replace()執(zhí)行一個正則表達式替換,其定義如下:

mixed preg_replace ( mixed $pattern , mixed $replacement , mixed $subject [, int $limit = -1 [, int &$count ]])

實際上就是搜索subject中匹配pattern的部分, 以replacement進行替換.其中l(wèi)imit指的是每個模式在每個subject上進行替換的最大次數(shù). 默認(rèn)是 -1(無限). 如果指定count,將會被填充為完成的替換次數(shù).

注意:

A,如果subject是一個數(shù)組, preg_replace()返回一個數(shù)組, 其他情況下返回一個字符串.

B,如果匹配被查找到, 替換后的subject被返回, 其他情況下返回沒有改變的subject. 如果發(fā)生錯誤, 返回NULL .

C,子模式可以應(yīng)用到參數(shù)replacement中,使用方式為\n或者${n}。(在正則表達式的模式中我們只能使用\n的形式來獲取已經(jīng)匹配的子模式,切記?。?/font>

D,如果使用模式修正符e,則參數(shù)replacement中可以解析函數(shù)。(在其它的正則表達式處理函數(shù)中,模式修正符e均被忽略!)

請看下面的綜合示例:

 
 
 
  1.     $pattern = '/(php)|(mysql)/e';    
  2.     $string = '這個字符串中的php和mysql被替換成大寫的了!';    
  3.     $result = preg_replace($pattern, 'strtoupper("${1}\2")', $string, -1, $count);    
  4.     echo $result.'
    ';    
  5.     echo $count;    
  6. ?>   

上例中,我們使用了模式修正符e,這樣的話strtoupper()函數(shù)就可以當(dāng)作字符串被解析,這就是模式修正符e的作用!而參數(shù)${1}和\2分別是子模式1和子模式2。上例的作用就是將字符串$string中匹配到的子模式php和mysql替換成大寫字母!

4,preg_split()函數(shù)。

preg_split執(zhí)行一個正則表達式分隔字符串。其定義如下:

array preg_split ( string $pattern , string $subject [, int $limit = -1 [, int $flags = 0 ]])

實際上就是將subject按照pattern分割,返回分割后的數(shù)組。其中,limit將限制分隔得到的子串最多只有l(wèi)imit個, 返回的最后一個子串將包含所有剩余部分.limit值為-1, 0或null時都代表"不限制"。

我們來看一個示例:

 
 
 
  1.      $pattern = '/

    (.*?)<\/p>/';    

  2.      $string = '這個字符串中的

    php

    mysql

    被分割了!';    
  3.      $result = preg_split($pattern, $string, -1, PREG_SPLIT_DELIM_CAPTURE);    
  4.      print_r($result);    
  5.  ?>   
  6.  

上例中,我們使用了常量PREG_SPLIT_DELIM_CAPTURE設(shè) 置返回結(jié)果中包含子模式(如果設(shè)置為PREG_SPLIT_NO_EMPTY,preg_split()將進返回分隔后的非空部分。)我們?nèi)绻焉侠姓?則表達式的括號去掉,則結(jié)果中不再包含php和mysql這兩個匹配成功的子模式。

常用的正則表達式處理函數(shù)我們就介紹完了,本節(jié)的例子可能會難一些,但希望大家還是認(rèn)真的試驗并體會一下,后面的正則表達式應(yīng)用部分,我們會經(jīng)常使用正則表達式處理函數(shù)。

原文地址:http://www.phpfuns.com/php/php-regexp-functions.shtml


分享題目:正則表達式之正則處理函數(shù)
瀏覽地址:http://www.5511xx.com/article/dhisogp.html