PHP發(fā)展基礎(chǔ)教程之正規(guī)表示式中的原子
一、原子
原子是正則表達(dá)示裡面的最小單位,原子說白了就是需要匹配的內(nèi)容。一個(gè)成立的正規(guī)表示示當(dāng)中必須最少要有一個(gè)原子。
所有可見不可見的字元就是原子
註:我們見到的空格、回車、換行、0-9、A-Za-z、中文、標(biāo)點(diǎn)符號(hào)、特殊符號(hào)全為原子。
在做原子的實(shí)例前我們先來講解一個(gè)函數(shù),preg_match:
語法:
int preg_match ( string $正規(guī), string $字串[, array &$結(jié)果] )
功能:根據(jù)$正規(guī)變量,匹配$字串變數(shù)。如果存在則回傳符合的個(gè)數(shù),把符合的結(jié)果放到$結(jié)果變數(shù)裡。如果沒有符合到結(jié)果回傳0
註:上面是preg_match常用的主要幾個(gè)參數(shù)。我在上面將另外幾個(gè)參數(shù)沒有列出來。因?yàn)?,另外兩個(gè)參數(shù)太不常用了。
我們來透過程式驗(yàn)證:
#實(shí)例:程式碼如下
<?php //定義一個(gè)變量pattern,存放正則表達(dá)式 $pattern = '/a/'; //待搜素字段 $string = 'ddfdjjvi2jfvkwkfi24'; //判斷,如果匹配到了,輸出$matcges的值 if(preg_match($pattern, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
結(jié)果:
因?yàn)槲蚁M氖瞧ヅ鋋,而$string當(dāng)是不存在a的,所以不成功。
改造這個(gè)範(fàn)例
實(shí)例:程式碼如下
<?php //定義一個(gè)變量pattern,存放正則表達(dá)式 $pattern = '/f/'; //待搜素字段 $string = 'ddfdjjvi2jfvkwkfi24'; //判斷,如果匹配到了,輸出$matcges的值 if(preg_match($pattern, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
結(jié)果:
##上面的字串裡面存在f,所以匹配成功接下來我們會(huì)匹配一個(gè)空格試試:實(shí)例:如下
<?php $zz = '/ /'; $string = 'sssssw aaaaa'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>##結(jié)果:
因上,$string這個(gè)變數(shù)的w字元後面存在一個(gè)空格。所以匹配成功,輸出了字串類型,長度為1。只不過我們的肉眼不可見,看不到這個(gè)字串而已。
二、特殊標(biāo)識(shí)的原子
上面已經(jīng)說明的很清楚了,我們進(jìn)行實(shí)驗(yàn)一步一步對(duì)這些進(jìn)行學(xué)習(xí)。
請(qǐng)你在學(xué)習(xí)的時(shí)候,對(duì)於這些原子務(wù)必達(dá)到默寫等級(jí)。因?yàn)椋覀円葬嶙鰧?shí)驗(yàn)的時(shí)候,一點(diǎn)一點(diǎn)你就學(xué)會(huì)了。
三、\d符合一個(gè)0-9#程式碼如下:
<?php $zz = '/\d/'; $string = '床9前明月光'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
四、\D符合一個(gè)非0-9的值#實(shí)例:程式碼如下
<?php header("Content-type:text/html;charset=utf-8"); $zz = '/\D/'; $string = '121243中23453453'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
五、\w符合一個(gè)a-zA- Z0-9_實(shí)例如下
<?php $zz = '/\w/'; $string = '新中_國萬歲呀萬歲'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
#六、\W符合一個(gè)非a-zA-Z0-9_#實(shí)例如下
<?php $zz = '/\W/'; $string = 'afasABCWEQR44231284737'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
七、\s 符合所有空白字元\n \t \r 空格##實(shí)例如下
<?php $zz = '/\s/'; $string = "中國萬 歲"; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
八、\S 非空白字元
#實(shí)例如下
<?php $zz = '/\S/'; $string = " a "; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
符合成功。雖然上面有空格,回車和縮排。但是,有一個(gè)非空白字元a。因此,匹配成功。
九、[] 指定範(fàn)圍的原子
#實(shí)例如下
<?php $zz = '/[0-5]\w+/'; $string = '6a'; $string1 = '1C'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
再試一次將$string改為$ string1,看看是不是配對(duì)到了
結(jié)論:
上例0-5符合$string失敗,而$string1成功。因?yàn)椋?string中的第一個(gè)數(shù)值為6,不在[0-5]的範(fàn)圍內(nèi)。
十、[^ 字元] 不符合指定區(qū)間的字元
#程式碼如下:
<?php $zz = '/[^0-9A-Za-z_]/'; $string = 'aaaaab311dd'; $string1 = '!$@!#%$#^##'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
##結(jié)論:
匹配$string不成功,但是匹配$string1的時(shí)候成功。因?yàn)橹欣ㄌ?hào)裡面有個(gè)抑揚(yáng)符。 ^ 抑揚(yáng)符在中括號(hào)裡面的作用是不準(zhǔn)以中括號(hào)裡面的字元進(jìn)行比對(duì)。十一、總結(jié)
#