国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

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

2020-03-22 20:03:54
字體:
供稿:網(wǎng)友
JavaScript中的第一個(gè)方式有點(diǎn)像,只是這里的話是個(gè)字符串。2.html' target='_blank'>正則表達(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被返回,其他情況下 返回沒有改變的 subject。如果發(fā)生錯(cuò)誤,返回 NULL。在代碼中$subject是一個(gè)數(shù)組,里面有兩組字符串,接下來是將多個(gè)數(shù)字替換為大寫的“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é)果。下面的代碼也是替換成大寫的“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”,里面沒有包含數(shù)字,在做匹配的時(shí)候,就把這個(gè)沒數(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:通過一個(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á)式的全部內(nèi)容介紹,希望對(duì)大家的學(xué)習(xí)有所幫助。PHP教程

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 通化市| 通化县| 巫山县| 汉寿县| 平舆县| 社会| 盱眙县| 景宁| 灯塔市| 会昌县| 开远市| 车致| 阿鲁科尔沁旗| 阳原县| 历史| 布尔津县| 伊通| 揭东县| 英吉沙县| 宣恩县| 闻喜县| 福泉市| 闵行区| SHOW| 阜平县| 龙海市| 屏边| 巴彦县| 舞阳县| 玉田县| 宁海县| 茌平县| 六盘水市| 武邑县| 张家界市| 桐城市| 光山县| 县级市| 固阳县| 蕲春县| 沅陵县|