亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

php正則表達(dá)式學(xué)習(xí)筆記

 更新時(shí)間:2015年11月13日 14:49:47   投稿:lijiao  
這篇文章主要介紹了學(xué)習(xí)php正則表達(dá)式,詳細(xì)深入的了解php正則表達(dá)式,從而更熟練掌握php正則表達(dá)式,感興趣的小伙伴們可以參考一下

php正則表達(dá)式學(xué)習(xí)筆記分享:

1.創(chuàng)建正則表達(dá)式

$regex = '/\d/i';
與JavaScript中的第一個(gè)方式有點(diǎn)像,只是這里的話是個(gè)字符串。

 2.正則表達(dá)式中的特殊字符

特殊字符有:   . \ + * ? [ ^ ] $ ( ) { } = ! < > | : -

3.正則表達(dá)式中的函數(shù)

有8個(gè)方法,preg_match與preg_match_all,preg_replace與preg_replace_callback,preg_grep、preg_split、preg_last_error和preg_quote。 

preg_match:

執(zhí)行一個(gè)正則表達(dá)式匹配

 

返回 pattern 的匹配次數(shù)。 它的值將是0次(不匹配)或1次,因?yàn)閜reg_match()在第一次匹配后,將會(huì)停止搜索。

$subject = "dd133aa2";
$pattern = '/\d+/';
preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE);
print_r($matches);

上面的示例代碼加了參數(shù)“PREG_OFFSET_CAPTURE”,這樣的話,在$matches中會(huì)多一個(gè)偏移數(shù)。例如下面的“2”

 

preg_match_all:

執(zhí)行一個(gè)“全局”正則表達(dá)式匹配

 

返回完整匹配次數(shù)(可能是0),或者如果發(fā)生錯(cuò)誤返回FALSE。

下面的代碼中$subject和$pattern與上面的都一樣,唯一不同的是preg_match換成了preg_match_all。

preg_match_all($pattern, $subject, $matches, PREG_OFFSET_CAPTURE);
print_r($matches);

返回的次數(shù)是2,匹配到了兩次,再看看數(shù)組$matches中的輸入,有兩個(gè)。比上面的多了一個(gè)。

 

 preg_replace:

執(zhí)行一個(gè)正則表達(dá)式的搜索和替換

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

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

在代碼中$subject是一個(gè)數(shù)組,里面有兩組字符串,接下來(lái)是將多個(gè)數(shù)字替換為大寫(xiě)的“Z”。

$subject = array("dd133aa2", "kk1ff3");
$pattern = '/\d+/';
$result = preg_replace($pattern, 'Z', $subject);
print_r($result);

preg_replace_callback:

執(zhí)行一個(gè)正則表達(dá)式搜索并且使用一個(gè)“回調(diào)”進(jìn)行替換

這個(gè)函數(shù)的行為除了可以指定一個(gè)callback替代replacement進(jìn)行替換 字符串的計(jì)算,其他方面等同于 preg_replace(),包括返回的結(jié)果。

下面的代碼也是替換成大寫(xiě)的“Z”,回調(diào)函數(shù)中每次$matches中的內(nèi)容就是代碼中注釋的部分,第一次是133,第二次是2。

$subject = "dd133aa2";
$pattern = '/\d+/';
$result = preg_replace_callback($pattern, function($matches) {
    //$matches [0] => 133
    //$matches [0] => 2
    return 'Z';
   }, $subject);
print_r($result); 

preg_grep:

返回匹配模式的數(shù)組條目

返回使用input中key做索引的數(shù)組。

下面的示例代碼中,在$subject數(shù)組中我加了個(gè)“ddsdfd”,里面沒(méi)有包含數(shù)字,在做匹配的時(shí)候,就把這個(gè)沒(méi)數(shù)字的給過(guò)濾掉了。

而$result2打印出來(lái)的正好相反,是把過(guò)濾的打印出來(lái)了,但是key還是為2,并不是0。

$subject = array("dd133aa2", "kk1ff3", "ddsdfd");
$pattern = '/\d+/';
$result = preg_grep($pattern, $subject);
$result2 = preg_grep($pattern, $subject, PREG_GREP_INVERT);
print_r($result);
print_r($result2);


preg_split:

通過(guò)一個(gè)正則表達(dá)式分隔字符串

 

返回一個(gè)使用 pattern 邊界分隔 subject 后得到 的子串組成的數(shù)組。

下面代碼中,我將$pattern中的表達(dá)式加了括號(hào),為了在$result2中捕獲到。

$subject = "dd133aa2cc";
$pattern = '/(\d+)/';
$result = preg_split($pattern, $subject);
$result2 = preg_split($pattern, $subject, null, PREG_SPLIT_DELIM_CAPTURE);
print_r($result);
print_r($result2);


preg_last_error:

返回最后一個(gè)PCRE正則執(zhí)行產(chǎn)生的錯(cuò)誤代碼

preg_match('/(?:\D+|<\d+>)*[!?]/', 'foobar foobar foobar');
$result = preg_last_error();//PREG_BACKTRACK_LIMIT_ERROR 調(diào)用回溯限制超出
print_r($result);

preg_quote:

轉(zhuǎn)義正則表達(dá)式字符

返回轉(zhuǎn)義后的字符串。

下面的代碼中,$subject中有兩個(gè)需要轉(zhuǎn)義的字符,“.”和“?”。

將$result打印出后是“dd\.a\?a2cc”,而在$result2中,多加了個(gè)參數(shù)“a”,這樣的話“a”也會(huì)被轉(zhuǎn)義,“dd\.\a\?\a2cc”

$subject = "dd.a?a2cc";
$result = preg_quote($subject);
$result2 = preg_quote($subject, 'a');
print_r($result);
print_r($result2);

4、模式修正符

以上就是關(guān)于php正則表達(dá)式的全部?jī)?nèi)容介紹,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

最新評(píng)論