php Regex學習筆記_Regex

來源:互聯網
上載者:User
複製代碼 代碼如下:

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


複製代碼 代碼如下:

//僅用於分組的括弧,匹配內容不會被變數捕獲,有時候需要這樣提高執行效率 
$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規範的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])
//也可以把匹配內容放到裡面,用:隔開,就不用寫結束(?-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)
複製內容到剪貼簿代碼:
//u修飾符,按unicode匹配
$str = '你您';
$str = preg_replace('/[你您]/', 'you', $str);
echo $str; //被拆開了,列印4次you
//看下面加上u修飾符後的效果,該修飾符需要編碼utf-8否則會報錯
//我的文本都是gb2312,所以要轉成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);
複製內容到剪貼簿代碼:
//排除環視(?<!...) (?!...)、忽略優先 *? +? ?? 的複合使用
$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);
//根據上面來完成一個最簡單的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)
//如果已經確認回朔並不會有匹配結果,可以使用固化分組來放棄備用狀態提高效率
$str = 'Subject';
preg_match('/(\w+):/', $str, $arr);
//用以下方法代替
//在第一組匹配規則匹配到文本末尾t時匹配結束,啟用第二組匹配規則:並不會找到結果,所以這個時候回朔尋找,但是\w不會包含:,所以可以直接放棄,
preg_match('/(?>\w+):/', $str, $arr);

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.