首页 > 编程 > Regex > 正文

php 正则表达式学习笔记

2020-03-16 21:18:58
字体:
来源:转载
供稿:网友
最近在学习正则,一些比较有用的东西怕忘记,记下来,比较乱,想一条记录一条:
 
 
复制代码代码如下:

//匹配文本,这个偶尔比较好用,但是要小心字符中包含/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); 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表