比较实用的正则表达式学习笔记

泰山日出天色略显昏暗,放眼望去,寂寥晨星下面是一片静止的山势般起伏的云海,在茫茫的夜色下,象极了远处同样黑魆魆的山峰。
//匹配文本,这个偶尔比较好用,但是要小心字符中包含\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
<fontsize=12></font>
<fontsize='13'></font>
<fontsize="14"></font>
<fontsize="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='<bstyle="COLOR:red"></b><bSTYLE="color:blue"></b><bstyle="color:green"></b>';
preg_match_all('/style=([\'"]?)(?i)color:(w+)1(?-i)/',$str,$arr);
print_r($arr[2]) //也可以把匹配内容放到里面,用?1,就不用写结束(?-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\'mateacher';
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='testTest';
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);

本文比较实用的正则表达式学习笔记到此结束。到不了的就是永远、忘不了的就是曾经。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
浅析golang 正则表达式

正则表达式如何解决input框固定输入值得格式(金额,特殊字符)

基于xpath选择器、PyQuery、正则表达式的格式清理工具详解

python中如何使用正则表达式将所有符合条件的字段全部提取出来

javascript正则表达式 限1-2位整数,或者至多含有两位小数的写法