最近在學(xué)習(xí)正則,一些比較有用的東西怕忘記,記下來(lái),比較亂,想一條記錄一條:
//匹配文本,這個(gè)偶爾比較好用,但是要小心字符中包含\E $str = '[a-z]'; $str = preg_replace('/\G[a-z]\E/', '', $str); echo $str; //打印空,全被替換掉了,相關(guān)大概就是preg_quote功能 復(fù)制內(nèi)容到剪貼板代碼: //給匹配結(jié)果命名,這樣在匹配結(jié)果中就可以用這個(gè)名稱來(lái)獲取值 $str = 'abc123abc'; preg_match('/(?P<num>\d+)/', $str, $arr); echo $arr['num']; //相當(dāng)于echo $arr[1]
//僅用于分組的括號(hào),匹配內(nèi)容不會(huì)被變量捕獲,有時(shí)候需要這樣提高執(zhí)行效率 $str = 'abc123abc'; preg_match('/abc(?:\d+)/', $str, $arr); echo $arr[1]; //除了$arr[0]外沒(méi)有$arr[1]了,不會(huì)賦予\1
//插入的好幫手,向前、向后錨點(diǎn)搜索位置,每3位添加一個(gè)逗號(hào) $str = 'fdfad123456789fdfd'; $str = preg_replace('/(?<=\d)(?=(\d{3})+(?!\d))/', ',', $str); echo $str; //打印 fdfad123,456,789fdfd
//以最少的結(jié)果匹配 $str = 123456; preg_match('/\d+/', $str, $arr); echo $arr[0]; //是人都知道是123456吧 preg_match('/\d+?/', $str, $arr); echo $arr[0]; //這次是1
//一個(gè)比較有用的,可以判斷前面的是否有匹配過(guò),比如下邊的例子,可以忽略等號(hào)右邊是否有單引號(hào)雙引號(hào)或者什么都沒(méi)有 $str = <<<HTML <font size=12></font> <font size='13'></font> <font size="14"></font> <font size="15></font> HTML; preg_match_all('/<font\s+size=([\'"]?)(\d+)\1[^>]*>/', $str, $arr); print_r($arr); /* Array ( [0] => 12 [1] => 13 [2] => 14 ) */
//部分模式修飾符,模式修飾符也可以放在表達(dá)式中的 //這里匹配符合XHTML規(guī)范的style里的顏色值,大寫的STYLE被忽略了,但是里面的color可以大小寫無(wú)所謂 $str = '<b style="COLOR:red"></b><b STYLE="color:blue"></b><b style="color:green"></b>'; preg_match_all('/style=([\'"]?)(?i)color:(\w+)\1(?-i)/', $str, $arr); print_r($arr[2]) //也可以把匹配內(nèi)容放到里面,用:隔開,就不用寫結(jié)束(?-i) //preg_match_all('/style=([\'"]?)(?i:color:(\w+))\1/', $str, $arr); //再看一例子 $str = '<B>Style</B>'; preg_match('/<B>(?i:style)<\/B>/', $str, $arr); print_r($arr); //可以匹配到 $str = '<B>Style</b>'; preg_match('/<B>(?i:style)<\/B>/', $str, $arr); print_r($arr); //什么都沒(méi)匹配到
//單詞檢索,可惜只能用在英文 $str = 'I\'m a teacher'; preg_match_all('/\b[a-z]+\b/i', $str, $arr); print_r($arr) 復(fù)制內(nèi)容到剪貼板代碼: //u修飾符,按unicode匹配 $str = '你您'; $str = preg_replace('/[你您]/', 'you', $str); echo $str; //被拆開了,打印4次you //看下面加上u修飾符后的效果,該修飾符需要編碼utf-8否則會(huì)報(bào)錯(cuò) //我的文本都是gb2312,所以要轉(zhuǎn)成utf-8 $str = iconv('gb2312', 'utf-8', '你您'); $regex = iconv('gb2312', 'utf-8', '/[你您]/u'); $str = preg_replace($regex, 'you', $str); echo $str; //打印2次you
//x模式修飾符,可以忽略空白和加注釋 $str = 'test Test'; preg_match('/test #只匹配小寫的test/x', $str, $arr); print_r($arr); 復(fù)制內(nèi)容到剪貼板代碼: //排除環(huán)視(?<!...) (?!...)、忽略優(yōu)先 *? +? ?? 的復(fù)合使用 $str = 'test <B>test1<B> test2</B>'; preg_match('/<B>(?:.(?<!<B>))*<\/B>/i', $str, $arr); //或者 preg_match('/<B>(?:(?!<B>).)*<\/B>/i', $str, $arr); print_r($arr) //當(dāng)時(shí)這樣寫應(yīng)付不了 $str = 'test <B>test1<B> test2</B> test3</B>'; //改寫一下正則既可 preg_match_all('/<B>(?:(?!<\/?B>).)*<\/B>/i', $str, $arr); //根據(jù)上面來(lái)完成一個(gè)最簡(jiǎn)單的UBB替換 $str = 'test [b]test1[b] test2[/b] test3[/b]test'; $str = preg_replace('/\[B\]((?:(?!\[\/?B\]).)*)\[\/B\]/i', '<b>\1</b>', $str); $str = preg_replace('/\[B\]((?:(?!\[\/?B\]).)*)\[\/B\]/i', '<b>\1</b>', $str); print_r($str)
//如果已經(jīng)確認(rèn)回朔并不會(huì)有匹配結(jié)果,可以使用固化分組來(lái)放棄備用狀態(tài)提高效率 $str = 'Subject'; preg_match('/(\w+):/', $str, $arr); //用以下方法代替 //在第一組匹配規(guī)則匹配到文本末尾t時(shí)匹配結(jié)束,啟用第二組匹配規(guī)則:并不會(huì)找到結(jié)果,所以這個(gè)時(shí)候回朔查找,但是\w不會(huì)包含:,所以可以直接放棄, preg_match('/(?>\w+):/', $str, $arr);
經(jīng)典論壇交流: http://bbs.blueidea.com/thread-2845941-1-1.html
本文鏈接:http://m.95time.cn/tech/program/2008/5678.asp
出處:藍(lán)色理想
責(zé)任編輯:bluehearts
◎進(jìn)入論壇網(wǎng)絡(luò)編程版塊參加討論
|