佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > 比較實(shí)用的正則表達(dá)式學(xué)習(xí)筆記

比較實(shí)用的正則表達(dá)式學(xué)習(xí)筆記

熱門(mén)標(biāo)簽:Mysql連接數(shù)設(shè)置 阿里云 電子圍欄 Linux服務(wù)器 服務(wù)器配置 團(tuán)購(gòu)網(wǎng)站 銀行業(yè)務(wù) 科大訊飛語(yǔ)音識(shí)別系統(tǒng)
//匹配文本,這個(gè)偶爾比較好用,但是要小心字符中包含\E
$str = '[a-z]';
$str = preg_replace('/\G[a-z]\E/', '', $str);
echo $str; //打印空,全被替換掉了,相關(guān)大概就是preg_quote功能

//給匹配結(jié)果命名,這樣在匹配結(jié)果中就可以用這個(gè)名稱來(lái)獲取值
$str = 'abc123abc';
preg_match('/(?Pnum>\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里的顏色值,大寫(xiě)的STYLE被忽略了,但是里面的color可以大小寫(xiě)無(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)容放到里面,用?1,就不用寫(xiě)結(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)

//u修飾符,按unicode匹配
$str = '你您';
$str = preg_replace('/[你您]/', 'you', $str);
echo $str; //被拆開(kāi)了,打印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  #只匹配小寫(xiě)的test/x', $str, $arr);
print_r($arr);

//排除環(huán)視(?!...) (?!...)、忽略優(yōu)先 *? +? ?? 的復(fù)合使用
$str = 'test B>test1B> test2/B>';
preg_match('/B>(?:.(?!B>))*\/B>/i', $str, $arr);
//或者 preg_match('/B>(?:(?!B>).)*\/B>/i', $str, $arr);
print_r($arr)

//當(dāng)時(shí)這樣寫(xiě)應(yīng)付不了 $str = 'test B>test1B> test2/B> test3/B>';
//改寫(xiě)一下正則既可 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);

標(biāo)簽:萍鄉(xiāng) 江蘇 衡水 大理 棗莊 衢州 蚌埠 廣元

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《比較實(shí)用的正則表達(dá)式學(xué)習(xí)筆記》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    静宁县| 象州县| 嫩江县| 准格尔旗| 视频| 治多县| 庆元县| 盐山县| 宽城| 济源市| 武乡县| 新平| 夏津县| 康平县| 新乡市| 贵溪市| 米脂县| 宁河县| 普安县| 河东区| 普格县| 金昌市| 赞皇县| 原阳县| 武隆县| 临高县| 凤翔县| 九寨沟县| 剑河县| 民丰县| 江川县| 蚌埠市| 阜康市| 石渠县| 渑池县| 莱州市| 子长县| 余姚市| 天等县| 中西区| 新干县|