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

首頁 > 編程 > Regex > 正文

php 正則表達式學習筆記

2020-03-16 21:18:58
字體:
供稿:網(wǎng)友
最近在學習正則,一些比較有用的東西怕忘記,記下來,比較亂,想一條記錄一條:
 
 
復制代碼代碼如下:

//匹配文本,這個偶爾比較好用,但是要小心字符中包含/E  
$str = '[a-z]';  
$str = preg_replace('//G[a-z]/E/', '', $str);  
echo $str; //打印空,全被替換掉了,相關大概就是preg_quote功能  
復制內(nèi)容到剪貼板代碼:  
//給匹配結果命名,這樣在匹配結果中就可以用這個名稱來獲取值  
$str = 'abc123abc';  
preg_match('/(?P<num>/d+)/', $str, $arr);  
echo $arr['num']; //相當于echo $arr[1] 


復制代碼代碼如下:

//僅用于分組的括號,匹配內(nèi)容不會被變量捕獲,有時候需要這樣提高執(zhí)行效率  
$str = 'abc123abc';  
preg_match('/abc(?:/d+)/', $str, $arr);  
echo $arr[1]; //除了$arr[0]外沒有$arr[1]了,不會賦予/1 

復制代碼代碼如下:

//插入的好幫手,向前、向后錨點搜索位置,每3位添加一個逗號  
$str = 'fdfad123456789fdfd';  
$str = preg_replace('/(?<=/d)(?=(/d{3})+(?!/d))/', ',', $str);  
echo $str; //打印 fdfad123,456,789fdfd 

//以最少的結果匹配 
$str = 123456; 
preg_match('//d+/', $str, $arr); 
echo $arr[0]; //是人都知道是123456吧 
preg_match('//d+?/', $str, $arr); 
echo $arr[0]; //這次是1 
//一個比較有用的,可以判斷前面的是否有匹配過,比如下邊的例子,可以忽略等號右邊是否有單引號雙引號或者什么都沒有 
$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 

*/ 
//部分模式修飾符,模式修飾符也可以放在表達式中的 
//這里匹配符合XHTML規(guī)范的style里的顏色值,大寫的STYLE被忽略了,但是里面的color可以大小寫無所謂 
$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)容放到里面,用:隔開,就不用寫結束(?-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); //什么都沒匹配到 
//單詞檢索,可惜只能用在英文 
$str = 'I/'m a teacher'; 
preg_match_all('//b[a-z]+/b/i', $str, $arr); 
print_r($arr) 
復制內(nèi)容到剪貼板代碼: 
//u修飾符,按unicode匹配 
$str = '你您'; 
$str = preg_replace('/[你您]/', 'you', $str); 
echo $str; //被拆開了,打印4次you 
//看下面加上u修飾符后的效果,該修飾符需要編碼utf-8否則會報錯 
//我的文本都是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); 
復制內(nèi)容到剪貼板代碼: 
//排除環(huán)視(?<!...) (?!...)、忽略優(yōu)先 *? +? ?? 的復合使用 
$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) 
//當時這樣寫應付不了 $str = 'test <B>test1<B> test2</B> test3</B>'; 
//改寫一下正則既可 preg_match_all('/<B>(?:(?!<//?B>).)*<//B>/i', $str, $arr); 
//根據(jù)上面來完成一個最簡單的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)確認回朔并不會有匹配結果,可以使用固化分組來放棄備用狀態(tài)提高效率 
$str = 'Subject'; 
preg_match('/(/w+):/', $str, $arr); 
//用以下方法代替 
//在第一組匹配規(guī)則匹配到文本末尾t時匹配結束,啟用第二組匹配規(guī)則:并不會找到結果,所以這個時候回朔查找,但是/w不會包含:,所以可以直接放棄, 
preg_match('/(?>/w+):/', $str, $arr); 

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 宁化县| 聂荣县| 广安市| 陆川县| 北川| 潍坊市| 中方县| 彰化县| 凤庆县| 浑源县| 台中县| 东至县| 丰都县| 陇川县| 尚志市| 舞钢市| 衡山县| 碌曲县| 大宁县| 济源市| 永康市| 桦川县| 苍南县| 霍山县| 定兴县| 西青区| 连平县| 正镶白旗| 浦江县| 绥江县| 浦江县| 罗平县| 临猗县| 旬阳县| 五河县| 绍兴市| 乡宁县| 隆子县| 北海市| 肇东市| 香格里拉县|