久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放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. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)

      前面我們知道正則表達(dá)式有很多元字符表示匹配次數(shù)(量詞),都是可以重復(fù)匹配前面出現(xiàn)的單個字符次數(shù)。有時候,我們可能需要匹配一組多個字符一起出現(xiàn)的次數(shù)。這個時候,我們需要分組了。就是用小括號來括起這些字符,指定子表達(dá)式(也叫做分組)。然后你就可以指定這個子表達(dá)式的重復(fù)次數(shù)了,你也可以對子表達(dá)式進(jìn)行其它一些操作。這個時候,可以把括號中一組字符,看作一個整體了。

      分組模式舉例說明

      如:查找字符串中,連續(xù)出現(xiàn)多個win字符串的字符。可以這樣完

        <?php   $str = "this is win winwindows!";  preg_match_all("/(win)+/",$str,$marr);  var_dump($marr);

      正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)

      不用分組模式,同時匹配多個字符,可以嗎? 我們發(fā)現(xiàn)以前操作符號:[win]+,盡管可以匹配到winwin字符,因?yàn)樗硎怯衱,i,n組合的一個或者多個字符,不會限制順序。所見它會匹配到象:wwin,www,inw等等,只要是這3個字符組成的,多個字符都匹配成功了。

      上面怎么匹配到,每一個有2個結(jié)果呢?這就是子模式(子匹配),默認(rèn)除了可以將多個字符組合一個整體,另外還會把括號,括起來的這部分表達(dá)式存儲到一個臨時緩沖區(qū)中,以便后面正則表達(dá)式調(diào)用。上面這個例子里面,我們不需要,后期調(diào)用的。因此,怎么樣屏蔽掉這個子表達(dá)式捕獲內(nèi)容呢? 只需要在:前加上”?:” 即可。我們看看下面例子正則表達(dá)式 分組非捕獲模式。

      正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)

      非捕獲模式優(yōu)點(diǎn)有哪些呢? 從上面看,可以減少捕獲,也就會減少匹配次數(shù)。因此,在不必要分組表達(dá)式加入非捕獲前綴”?:”,可以節(jié)省內(nèi)存開銷,并且可以提升匹配速度!

      剛剛說到了正則表達(dá)式分組,默認(rèn)情況會將子表達(dá)式捕獲內(nèi)容,存儲到一個緩存區(qū)。以便后續(xù)調(diào)用。 那這個是什么樣情況呢?其實(shí),這個是正則表達(dá)式的引用。所捕獲的每個子匹配都按照在正則表達(dá)式模式中從左至右所遇到的內(nèi)容按順序存儲。存儲子匹配的緩沖區(qū)編號從1開始,最多可以一般存儲為9。以便后面表達(dá)式引用該值,又叫后向引用。

      我們看下下面例子,查找一個字符串中,互不相鄰,出現(xiàn)多次系統(tǒng)單詞:add。

        <?php  $str = "add123456addasdf";   preg_match_all('/(add)d+1/',$str,$marr);   var_dump($marr);

      正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)

      反向引用,常用來處理一些處理一些特殊匹配情況。如:查找字符串中,不相鄰重復(fù)字符串。查找html一對標(biāo)簽中內(nèi)容。特別分析html非常常見了(注意,如果使用了反向引用,前面不能屏蔽子匹配捕獲,也就是不能加”?:”前綴了)。經(jīng)常會用:

        <?php  $str = file_get_contents('http://blog.chacuo.net/');  preg_match_all('/<(S+)[^>]*>[^<]*</1>/',$str,$marr);     var_dump($marr);     // (S+) 表示非顯示字符之外所有字符,一般作為html tag名稱  // tag格式一般為 <tag  其它屬性> 后面[^>]* 匹配tag里面所有其它屬性  // 后面的[^<]* 表示 <tag...>中間內(nèi)容</tag> 表示中間內(nèi)容,到"<"結(jié)束,因此匹配所有[^<]* 字符  // 最后的</1> "/" 轉(zhuǎn)義"/"字符,后面的"1" 表示反向應(yīng)用前面的(S+)

      正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)

      以上是正則表達(dá)式使用比較重要的,分組,反向匹配,以及非捕獲分組說明及實(shí)例。希望對要屬性改功能朋友有所幫助。同時歡迎朋友們交流!

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