最新公告
  • 欢迎您访问爱上源码网,分享精品整站源码,网站模板,游戏源码,APP小程序源码以及视频教程免费下载;服务永无止境!立即加入我们
  • PHP中正则表达式详解(代码实例)

    本文目标:

    1、正则表达式的定义

    2、正则表达式的几个基本语法

    (一)、正则表达式的定义

    正则表达式是对字符串进行操作的一种逻辑公式,就是用一些特定的字符组合成一个规则字符串

    比如:

    <?php
    $p = '/abc123/';
    $str = "abc123bbbb";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则';
    }
    ?>

    上述代码中的’/abc123/’就是一个正则表达式,我们从中可以看出,/abc123/就是一串由字符和数字组成的字符串,只不过这些字符在里面有其特殊的含义,比如/abc123/这个正则表达式的规则是,字符串以abc123开头,任何字符串符合这个规则就它就和这个表达式相匹配了

    (二)、正则表达式的几个基本语法

    1、正则匹配模式使用分隔符与元字符组成,分隔符可以是非数字、非反斜线、非空格的任意字符。常见的分隔符比如正斜线(/)、hash符号(#) 以及取反符号(~)

    举例如:

    /hello world/ 表达式的意思是:字符串以hellow world开头
    #^[0-9]$# 表达式的意思是:匹配0-9的数字
    ~hello~ 表达式的意思是:字符串包含hello

    我们用代码来测试一下

    例一

    /hello world/ 表达式的意思是:字符串以hellow world开头

    <?php
    $p = "/hello world/";
    $str = "hello world,i am a student";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则/hello world/<br/>';
    }
    
    ?>

    运行结果如下:

    该字符串符合这个规则/hello world/

    换一个字符串看下,不以hello world开头

    <?php
    $p = "/hello world/";
    $str = "helloworld,i am a student";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则/hello world/<br/>';
    }
    
    ?>

    运行结果为:

    空白

    例二

    #^[0-9]$# 表达式的意思是:匹配0-9的数字

    <?php
    $p2 = "#^[0-9]$#";
    $str2 = "3";
    if (preg_match($p2, $str2)) {
        echo '该字符串符合这个规则"#^[0-9]$#<br/>';
    }
    ?>

    运行结果为:

    该字符串符合这个规则”#^[0-9]$#

    代码改一下,字符串改成一个大于9的数字看下

    <?php
    $p2 = "#^[0-9]$#";
    $str2 = "30";
    if (preg_match($p2, $str2)) {
        echo '该字符串符合这个规则"#^[0-9]$#<br/>';
    }else{
        echo '该字符串不符合这个规则"#^[0-9]$#<br/>';
    }
    ?>

    运行结果为:

    该字符串不符合这个规则”#^[0-9]$#

    例三、

    ~hello~ 表达式的意思是:字符串包含hello

    具体代码如下:

    <?php
    $p3 = "~hello~";
    $str3 = "ahellobb";
    if (preg_match($p3, $str3)) {
        echo '该字符串符合这个规则:~hello~';
    }else{
        echo '该字符串不符合这个规则:~hello~';
    }
    ?>

    运行结果为:

    该字符串符合这个规则:~hello~

    现在把测试字符串改成不包含hellow

    具体代码如下:

    <?php
    $p3 = "~hello~";
    $str3 = "hell o";
    if (preg_match($p3, $str3)) {
        echo '该字符串符合这个规则:~hello~';
    }else{
        echo '该字符串不符合这个规则:~hello~';
    }
    ?>

    运行结果为:

    该字符串不符合这个规则:~hello~

    由此可见:

    1、/表示开头

    2、^表示以^后面的字符开始

    3、$表示以$前面的字符结束

    4、~表示包含的意思

    2、如果模式中包含分隔符,则分隔符需要使用反斜杠(\)进行转义。

    比如:

    /https:\/\/www./ 表示以https://www.开头

    具体代码如下:

    <?php
    $p = "/https:\/\/www./";
    $str = "https://www.baidu.com";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则:/https:\/\/www./';
    }else{
        echo '该字符串不符合这个规则:/https:\/\/www./';
    }

    运行结果为:

    该字符串符合这个规则:/https:\/\/www./

    试着将字符串 改成不以https://www.开头看下

    <?php
    $p = "/https:\/\/www./";
    $str = "http://www.baidu.com";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则:/https:\/\/www./';
    }else{
        echo '该字符串不符合这个规则:/https:\/\/www./';
    }

    运行结果为:

    该字符串不符合这个规则:/https:\/\/www./

    3、如果模式中包含较多的分割字符,建议更换其他的字符作为分隔符,也可以采用preg_quote进行转义。

    例一、

    <?php
    
    $p = "/https://www.baidu.com/a/b/index.html/";
    $str = "http://www.baidu.com/a/b/index.html";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/';
    }else{
        echo '该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/';
    }

    运行结果为:

    Warning: preg_match(): Unknown modifier ‘/’ in D:\E-class\class-code\classing\index.php on line 7
    该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/

    所以此时不能直接写/要么按照上面的进行转义,要么按照下面的方式进行

    具体代码如下:

    <?php
    $p = "https://www.baidu.com/a/b/index.html";
    $p = '/'.preg_quote($p, '/').'/';
    $str = "https://www.baidu.com/a/b/index.html";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/';
    }else{
        echo '该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/';
    }
    ?>

    运行结果为:

    该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/

    4、分隔符后面可以使用模式修饰符,模式修饰符包括:i,m, s,等

    总结:

    1、i 表示可以忽略大小写

    2、m表示多行匹配

    3、如果设定了此修正符,模式中的圆点元字符(.)匹配所有的字符,包括换行符。没有此设定的话,则不包括换行符。

    案例一、

    实践目标:

    1、i 表示可以忽略大小写

    <?php
    $p = "/ABc/i";
    $str = "abc";
    if (preg_match($p, $str)) {
        echo '该字符串符合这个规则:/ABc/i';
    }else{
        echo '该字符串不符合这个规则:/ABc/i';
    }
    ?>

    运行结果为:

    该字符串符合这个规则:/ABc/i

    案例二、

    实践目标:

    1、m表示多行匹配

    具体代码如下:

    <?php
    $p = "/chinese/m";
    $str = "i am a chinese people,\n you alose is a chinese people";
    $math = "";
    if (preg_match_all($p, $str,$math)) {
        echo '该字符串符合这个规则:/chinese/m,匹配结果为:';
        print_r($math);
    }else{
        echo '该字符串不符合这个规则:/chinese/m';
    }
    ?>

    运行结果为:

    该字符串符合这个规则:/chinese/m,匹配结果为:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )

    这里要注意的是一定要用preg_match_all否则用preg_match它只会匹配一行

    接下来我们运行下效果

    <?php
    $p = "/chinese/m";
    $str = "i am a chinese people,\n you alose is a chinese people";
    $math = "";
    if (preg_match($p, $str,$math)) {
        echo '该字符串符合这个规则:/chinese/m,匹配结果为:';
        print_r($math);
    }else{
        echo '该字符串不符合这个规则:/chinese/m';
    }
    ?>

    运行结果为:

    该字符串符合这个规则:/chinese/m,匹配结果为:Array ( [0] => chinese )

    其实/m在此也算多此一举,因为preg_match_all就是表示多行匹配了

    <?php
    $p = "/chinese/";
    $str = "i am a chinese people,\n you alose is a chinese people";
    $math = "";
    if (preg_match_all($p, $str,$math)) {
        echo '该字符串符合这个规则,匹配结果为:';
        print_r($math);
    }else{
        echo '该字符串不符合这个规则';
    }
    
    ?>

    运行结果其实是一样的,结果为:

    该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )

    只是要知道m表示多行匹配的意思

    案例三、

    实践目标:

    1、如果设定了此修正符,模式中的圆点元字符(.)匹配所有的字符,包括换行符。没有此设定的话,则不包括换行符。

    具体代码如下:

    <?php
    $p = "/chinese ./s";
    $str = "i am a chinese \n people, you alose is a chinese good people";
    $math = "";
    if (preg_match_all($p, $str,$math)) {
        echo '该字符串符合这个规则,匹配结果为:';
        print_r($math);
    }else{
        echo '该字符串不符合这个规则';
    }
    ?>

    运行结果如下:

    该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese [1] => chinese g ) )

    说明第一个chinese 后面的字符是换行也匹配到了,这说明了s的意思就是.要包含换行符,接下来

    我们去掉s,看下最终的结果

    <?php
    $p = "/chinese ./";
    $str = "i am a chinese \n people, you alose is a chinese good people";
    $math = "";
    if (preg_match_all($p, $str,$math)) {
        echo '该字符串符合这个规则,匹配结果为:';
        print_r($math);
    }else{
        echo '该字符串不符合这个规则';
    }
    ?>

    运行结果如下:

    该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese g ) )

    说明此刻只匹配到一个了,因为.不包含换行符,所以第一个chinese没有匹配到

    总结:

    本文主要讲解了

    1、正则表达式的定义

    2、正则表达式的几个基本语法

    以上就是PHP中正则表达式详解(代码实例)的详细内容,更多请关注爱上源码网其它相关文章!

  • 微信
  • 分享
  • 相关标签:正则表达式 PHP
  • 本文原创发布爱上源码网,转载请注明出处,感谢您的尊重!
    • 上一篇:php如何实现header跳转
    • 下一篇:php中session时间设置浅析

    相关文章

    相关视频

    • 正则表达式中模式修正符作用详解
    • php基础知识考察点之正则表达式
    • php中常用的正则表达式使用方法
    • php中如何使用正则表达式删除a标签
    • PHP中正则表达式详解(代码实例)
    • 动态路由传参-正则表达式
    • 正则表达式
    • 初识 Python 正则表达式
    • 11_正则表达式-字符次数

    本文有爱上源码下载完入驻作者发布,如果对您版权造成侵害,可以联系本站站长管理进行维权删除,本站收到维权24小时内进行处理,谢谢您关注23ym.cn!
    本站分享大量程序员技术文章以及对编程开发的初级入门教程,包括图文讲解笔记和高清视频下载~

    重要声明:
    1.本站视频教程,软件及网站源码版权均属于原作者所有,您必须在下载后的24个小时之内,从您的电脑中删除!非法商业用途,后果自负!
    2.本站不保证所提供下载资源的安全性和完整性,仅供下载学习之用!如链接失效或资源含外站广告,请联系客服处理!给予奖励!
    3.本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!本站提供有偿服务!如有侵权请联系在线客服!
    4.如您手中有优质资源或教程,可以自助投稿发布,成功分享后有奖励和额外收入!
    5.如您需要正版微擎模块可联系本站客服,我们有价值30w+商业微擎应用出售微擎坑位和招收代理!
    6.400电话/软著/ICP,EDI许可证/商标特价办理中!
    爱上源码下载网 » PHP中正则表达式详解(代码实例)

    常见问题FAQ

    从网站下载的源码都有安装教程么?不会安装怎么办?
    本站发布的网站源码和模板资源大部分在压缩包内都有教程,如您不会安装可以联系本站在线技术进行付费安装。
    爱上源码的所有源码都是亲测能正常运行的么?
    本站目前拥有资源10w+,包含整站源码,网站模板,游戏源码,小程序源码,视频教程,破解软件等,每天也在测试更新;因时间和精力有限我们无法对资源进行一一测试,只能保证所分享资源内容无误,希望理解。
    我手中的优质资源可以在你这换钱或者VIP么?
    爱上源码支持投稿,欢迎发布您手中的优质资源进行售卖;本站VIP支持免费获取,目前邀请10人注册爱上源码即可免费获取VIP。
    爱上源码除了资源分享还有其他业务没?
    【价值30W+微擎模块出售正版商业微擎坑位及招收代理,详情咨询本站客服!】我们团队目前运营并推广几套商业化saas智能小程序系统能满足大部分小程序开发需求,并由SaaS和独立部署版商城小程序系统;另外销售400电话,各种ICP/EDI资质证书办理,软著和商标注册服务等。

    发表评论

    • 32会员总数(位)
    • 35644资源总数(个)
    • 0本周发布(个)
    • 0 今日发布(个)
    • 657稳定运行(天)

    提供最优质的资源集合

    开通VIP 源码下载