做者:极客小俊 一个专一于web技术的80后
我不用拼过聪明人,我只须要拼过那些懒人 我就必定会超越大部分人!
CSDN@极客小俊,原创文章, B站技术分享
B站视频 : 👉 Bilibili.com 👈
我的博客: 👉 cnblogs.com 👈php
在咱们说php系统自带的正则处理函数以前,咱们先要回忆一下在PHP中正则表达式的组成元素有哪些? 以下:web
例如:一个匹配URL的正则表达式以下正则表达式
$url="/(https?|ftps?):\/\/(www|mail|news)\.([^\.\/]+)\.(com|org|net)/i";
应用以下案例:数组
$pattern="/(https?|ftps?):\/\/(www|mail|news)\.([^\.\/]+)\.(com|org|net)/i"; $string='http://www.baidu.com'; preg_match($pattern, $string,$arr); show($arr);
PHP中正则表达式与PHP正则处理函数结合使用
在PHP中正则表达式不能独立使用、它只是一种用来定义字符串的规则模式、因此必须在、
相应的正则表达式函数中应用、才能实现相应的功能! 例如 匹配、分割、查找、替换
因此有了正则,再加上PHP正则处理函数来使用这个正则表达式,才能对字符串进行
分割、匹配、查找及替换等工做。函数
把一个正则表达式用在分割的函数中, 则使用这个正则表达式对字符串进行分割
把一个正则表达式用在匹配的函数中, 则使用这个正则表达式对字符串进行匹配
把一个正则表达式用在替换的函数中, 则使用这个正则表达式对字符串进行替换
把一个正则表达式用在查找的函数中, 则使用这个正则表达式对字符串进行查找性能
小提示: 能使用字符串处理函数完成的功能,就不要使用正则表达式处理函数 性能问题学习
preg_match(参数..)
做用: 在第一次匹配后将会中止搜索、返回正则的匹配次数 ,若是匹配返回1,不匹配返回0
发生错误返回false!
参数列表以下:
参数1:正则表达式
参数2:字符串
参数3:自定义存放结果数组
参数4:获取目标字符串的开始下标值常量,
参数5:搜索目标字符的开始位置
案例以下:url
$string='www.baidu.com'; $pattern="/baidu/i"; preg_match($pattern, $string,$arr); show($arr);
preg_match_all(参数..)
做用:在匹配找到第一个后, 继续从这个匹配位置搜索 直到把全部符合正则的都匹配出来
而后返回完整匹配数量次数,若是返回0次 说明没有匹配,发生错误返回false.!
参数列表以下:
参数1:正则表达式
参数2:字符串
参数3:自定义存放结果数组
参数4:以什么方式排列结果常量: PREG_SET_ORDER、
参数5:搜索目标字符的开始位置
案例以下:spa
$string='www.baidu.com www.sina.com www.bilibili.com'; $pattern="/www\..+?(\.com)/"; preg_match_all($pattern, $string,$arr); show($arr);
例1:查找字符串中出全部的URL 而且把全部URL地址加上红颜色后打印输出字符串。 以下code
$string='北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发'; //处理以前 echo nl2br($string); echo '<hr>'; $pattern="/(?:http[s]?|ftp?):\/\/(?:www|mail)\.[^\.\/]*\.(?:com|org|net)/i"; preg_match_all($pattern, $string,$arr); $num=0; foreach ($arr[0] as $key=>$val){ $string=str_replace($val, '<span style="color:red;">'.$val.'</span>', $string,$count); $num+=$count; } //处理以后 echo nl2br($string).'<br>替换的次数是'.$num.'次';
例2:查找字符串中出全部的URL 而且把全部URL地址替换成超级连接而后打印输出字符串, 以下:
$string='北京市朝阳区http://www.sina.com中国区PHP开发 北京市朝阳区http://www.baidu.com中国区PHP开发 北京市朝阳区http://www.163.com中国区PHP开发 北京市朝阳区http://www.wangm.com中国区PHP开发 北京市朝阳区http://www.albb.com中国区PHP开发'; //处理以前 echo nl2br($string); echo '<hr>'; function setURL($string){ $pattern="/(?:http[s]?|ftp?):\/\/(?:www|mail)\.[^\.\/]*\.(?:com|org|net)/i"; preg_match_all($pattern, $string,$arr); foreach($arr[0] as $k=>$v){ $replace='<a href="'.$v.'">'.$v.'</a>'; $string=str_replace($v, $replace, $string); } return nl2br($string); } echo '<hr>'; //处理以后 echo setURL($string);
"点赞" "评论" "收藏"