php正則表達式學(xué)習(xí)筆記
php正則表達式學(xué)習(xí)筆記分享:
1.創(chuàng)建正則表達式
$regex = '/\d/i';
與JavaScript中的第一個方式有點像,只是這里的話是個字符串。
2.正則表達式中的特殊字符
特殊字符有: . \ + * ? [ ^ ] $ ( ) { } = ! < > | : -
3.正則表達式中的函數(shù)
有8個方法,preg_match與preg_match_all,preg_replace與preg_replace_callback,preg_grep、preg_split、preg_last_error和preg_quote。
preg_match:
執(zhí)行一個正則表達式匹配
返回 pattern 的匹配次數(shù)。 它的值將是0次(不匹配)或1次,因為preg_match()在第一次匹配后,將會停止搜索。
$subject = "dd133aa2"; $pattern = '/\d+/'; preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE); print_r($matches);
上面的示例代碼加了參數(shù)“PREG_OFFSET_CAPTURE”,這樣的話,在$matches中會多一個偏移數(shù)。例如下面的“2”
preg_match_all:
執(zhí)行一個“全局”正則表達式匹配
返回完整匹配次數(shù)(可能是0),或者如果發(fā)生錯誤返回FALSE。
下面的代碼中$subject和$pattern與上面的都一樣,唯一不同的是preg_match換成了preg_match_all。
preg_match_all($pattern, $subject, $matches, PREG_OFFSET_CAPTURE); print_r($matches);
返回的次數(shù)是2,匹配到了兩次,再看看數(shù)組$matches中的輸入,有兩個。比上面的多了一個。
preg_replace:
執(zhí)行一個正則表達式的搜索和替換
如果subject是一個數(shù)組, preg_replace()返回一個數(shù)組, 其他情況下返回一個字符串。
如果匹配被查找到,替換后的subject被返回,其他情況下 返回沒有改變的 subject。如果發(fā)生錯誤,返回 NULL。
在代碼中$subject是一個數(shù)組,里面有兩組字符串,接下來是將多個數(shù)字替換為大寫的“Z”。
$subject = array("dd133aa2", "kk1ff3"); $pattern = '/\d+/'; $result = preg_replace($pattern, 'Z', $subject); print_r($result);
preg_replace_callback:
執(zhí)行一個正則表達式搜索并且使用一個“回調(diào)”進行替換
這個函數(shù)的行為除了可以指定一個callback替代replacement進行替換 字符串的計算,其他方面等同于 preg_replace(),包括返回的結(jié)果。
下面的代碼也是替換成大寫的“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ù)組中我加了個“ddsdfd”,里面沒有包含數(shù)字,在做匹配的時候,就把這個沒數(shù)字的給過濾掉了。
而$result2打印出來的正好相反,是把過濾的打印出來了,但是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:
通過一個正則表達式分隔字符串
返回一個使用 pattern 邊界分隔 subject 后得到 的子串組成的數(shù)組。
下面代碼中,我將$pattern中的表達式加了括號,為了在$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:
返回最后一個PCRE正則執(zhí)行產(chǎn)生的錯誤代碼
preg_match('/(?:\D+|<\d+>)*[!?]/', 'foobar foobar foobar'); $result = preg_last_error();//PREG_BACKTRACK_LIMIT_ERROR 調(diào)用回溯限制超出 print_r($result);
preg_quote:
轉(zhuǎn)義正則表達式字符
返回轉(zhuǎn)義后的字符串。
下面的代碼中,$subject中有兩個需要轉(zhuǎn)義的字符,“.”和“?”。
將$result打印出后是“dd\.a\?a2cc”,而在$result2中,多加了個參數(shù)“a”,這樣的話“a”也會被轉(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正則表達式的全部內(nèi)容介紹,希望對大家的學(xué)習(xí)有所幫助。
相關(guān)文章
生成靜態(tài)頁面的php函數(shù),php愛好者站推薦
生成靜態(tài)頁面的php函數(shù),php愛好者站推薦...2007-03-03echo, print, printf 和 sprintf 區(qū)別
echo, print, printf 和 sprintf 區(qū)別...2006-12-12關(guān)于IIS php調(diào)用com組件的權(quán)限問題
Word的對象庫文件“MSWORD.OLB”(word 2000為MSWORD9.OLB)(這是針對老版本的情況,在用vs.net2005的時候,直接在引用對話框中,在com組件里找到對word的庫文件的引用就可以了,文件名好像是一樣的2012-01-01