国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

php 正則表達(dá)示中的原子

原子

原子是正則表達(dá)示里面的最小單位,原子說白了就是需要匹配的內(nèi)容。一個成立的正則表達(dá)示當(dāng)中必須最少要有一個原子。

所有可見不可見的字符就是原子

說明:我們見到的空格、回車、換行、0-9、A-Za-z、中文、標(biāo)點符號、特殊符號全為原子。

在做原子的實例前我們先來講解一個函數(shù),preg_match:

int preg_match ( string $正則 , string $字符串 [, array &$結(jié)果] )

功能:根據(jù)$正則變量,匹配$字符串變量。如果存在則返回匹配的個數(shù),把匹配到的結(jié)果放到$結(jié)果變量里。如果沒有匹配到結(jié)果返回0。

注:上面是preg_match常用的主要幾個參數(shù)。我在上面將另外幾個參數(shù)沒有列出來。因為,另外兩個參數(shù)太不常用了。

我們來通過實驗來證明:

<?php
//定義一個變量叫zz,放正則表達(dá)示。為了方便大家記憶,如果你英文比較ok,建議把變量名還是寫成英文的$pattern。
$zz = '/a/';

$string = 'ddfdjjvi2jfvkwkfi24';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

因為我希望的是匹配a,而$string當(dāng)是是不存在a的,所以不成功。

<?php
$zz = '/wq/';

$string = 'ssssswqaaaaaa';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

上面的字符串中s后存在wq,因此匹配成功。

接下來我們匹配一個空格試試:

<?php
$zz = '/ /';

$string = 'sssssw aaaaa';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

執(zhí)行結(jié)果如下:

QQ截圖20161114135142.png

因上,$string這個變量的w字符后存在一個空格。所以匹配成功,輸出了字符串類型,長度為1。只不過我們的肉眼不可見,看不到這個字符串而已。

特殊標(biāo)識的原子

原子說明
d匹配一個0-9
D除了0-9以外的所有字符
wa-zA-Z0-9_
W除了0-9A-Za-z_以外的所有字符
s匹配所有空白字符n t r 空格
S匹配所有非空白字符
[ ]指定范圍的原子


這個個需要記住,最好達(dá)到默寫級別。記憶的時候成對記憶,d是匹配一個0-9,那么D 就是除了0-9以外的所有字符。
上面已經(jīng)說明的很清楚了,我們進(jìn)行實驗一步一步對這些進(jìn)行學(xué)習(xí)。

請你在學(xué)習(xí)的時候,對于這些原子務(wù)必達(dá)到默寫級別。因為,我們以后做實驗的時候,一點一點你就學(xué)會了。

d匹配一個0-9

<?php
$zz = '/\d/';

$string = '我愛喝9你愛不愛喝';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

D匹配一個非0-9的值

<?php
$zz = '/\D/';

$string = '121243中23453453';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

匹配成功,匹配到了中。因為它不是0-9之間的字符。

w匹配一個a-zA-Z0-9_

<?php
$zz = '/\w/';

$string = '新中_國萬歲呀萬歲';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

匹配成功,匹配到了下劃線。

W匹配一個非a-zA-Z0-9_

<?php
$zz = '/\w/';

$string = 'afasABCWEQR44231284737';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

匹配失敗。因為,上面上面全是a-zA-Z0-9_,沒有非a-zA-Z0-9_。

s 匹配所有空白字符n t r 空格

<?php
$zz = '/\s/';

$string = "中國萬
歲";

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

匹配成功,因為有一個回車。

S 非空字符

<?php
$zz = '/\s/';

$string = "        
         a       ";

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

匹配成功。雖然上面有空格,回車和縮進(jìn)。但是,有一個非空白字符a。因此,匹配成功。

[] 指定范圍的原子

<?php

$zz = '/[0-5]\w+/';

$string = '6a';

$string1 = '1C';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

結(jié)論:
上例中0-5匹配$string失敗,而$string1成功。因為,$string中的第一個數(shù)值為6,不在[0-5]的范圍之內(nèi)。

<?php

$zz = '/[a-zA-Z0-9_]\w/';

$string = 'ab';

$string1 = '9A';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

結(jié)論:

$string和$string1都匹配成功。因為w就是[a-zA-Z0-9_]

<?php

$zz = '/[abc]\d+/';

$string = 'a9';

$string1 = 'b1';

$string2 = 'c5';

$string3 = 'd4';


if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

結(jié)論:

$string、$string1、$string2匹配成功,而$string3不成功。因為$string3超過了[abc]的范圍,它是從d開始的。

[^ 字符] 不匹配指定區(qū)間的字符

<?php

$zz = '/[^0-9A-Za-z_]/';

$string = 'aaaaab311dd';

$string1 = '!$@!#%$#^##';

if(preg_match($zz, $string, $matches)){
   echo '匹配到了,結(jié)果為:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

?>

結(jié)論:

????1.匹配$string不成功,但是匹配$string1的時候成功。因為中括號里面有個抑揚(yáng)符。

????2.^ 抑揚(yáng)符在中括號里面的作用是不準(zhǔn)以中括號里面的字符進(jìn)行匹配。

總結(jié):

原子等價式
w[a-zA-Z0-9_]
W[^a-zA-Z0-9_]
d[0-9]
D[^0-9]
s[ tnfr]
S[^ tnfr]
繼續(xù)學(xué)習(xí)
||
<?php $zz = '/[^0-9A-Za-z_]/'; $string = 'aaaaab311dd'; $string1 = '!$@!#%$#^##'; if(preg_match($zz, $string, $matches)){ echo '匹配到了,結(jié)果為:'; var_dump($matches); }else{ echo '沒有匹配到'; } ?>
提交重置代碼