首页前端开发其他前端知识php 正则表达式学习笔记

php 正则表达式学习笔记

时间2024-02-01 13:45:02发布访客分类其他前端知识浏览1107
导读:收集整理的这篇文章主要介绍了php 正则表达式学习笔记,觉得挺不错的,现在分享给大家,也给大家做个参考。 复制代码 代码如下://匹配文本,这个偶尔比较好用,但是要小心字符中包含\E ...
收集整理的这篇文章主要介绍了php 正则表达式学习笔记,觉得挺不错的,现在分享给大家,也给大家做个参考。 复制代码 代码如下:
//匹配文本,这个偶尔比较好用,但是要小心字符中包含\E 
$str = '[a-z]';  
$str = PReg_replace('/\G[a-z]\E/', '', $str);  
echo $str;  //打印空,全被替换掉了,相关大概就是preg_quote功能 
复制内容到剪贴板代码: 
//给匹配结果命名,这样在匹配结果中就可以用这个名称来获取值 
$str = 'abc123abc';  
preg_match('/(?Pnum> \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> test1B>  test2/B> ';
preg_match('/B> (?:.(?!B> ))*\/B> /i', $str, $arr);
//或者 preg_match('/B> (?:(?!B> ).)*\/B> /i', $str, $arr);
print_r($arr)
//当时这样写应付不了 $str = 'test B> test1B>  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);
您可能感兴趣的文章:
  • 正则表达式口诀_学习正则的朋友值得一看
  • 正则表达式口诀 正则表达式学习工具
  • 正则表达式 学习资料整理
  • 正则表达式 学习参考 推荐入门者看
  • JS 正则表达式(学习笔记2)匹配网址url参数
  • Python模块学习 re 正则表达式
  • javascript的正则表达式学习资料复习
  • 重温JavaScript中的正则表达式 js学习笔记
  • 正则表达式学习问答
  • Java 正则表达式学习总结和一些小例子
  • MySql官方手册学习笔记2 MySql的模糊查询和正则表达式
  • js 正则表达式学习笔记之匹配字符串
  • Powershell学习笔记--使用正则表达式查找文件
  • 正则表达式详细介绍(上)

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

php正则表达式

若转载请注明出处: php 正则表达式学习笔记
本文地址: https://pptw.com/jishu/595477.html
正则表达式口诀 asp+正则获得字符串中最后一个字母非字母不算

游客 回复需填写必要信息