• 关于正则表达式中^和$


    ^是正则表达式匹配字符串开始位置

    $是正则表达式匹配字符串结束位置

    很多人始终没搞清楚这是什么意思,这里用几个例子看下就一目了然了。

    先搞清楚^匹配字符串开始位置(其实就是从字符串左边第一个字符开始匹配)

    1 $str='http://blog.seetiny.com';
    2 $pattern='/^blog/';  /*因为/为特殊字符*/
    3 $str=preg_replace($pattern,'jimmy',$str);
    4 echo $str;die;

    上面的输出是:

    http://blog.seetiny.com/

    改造一下:

    1 $str='http://blog.seetiny.com';
    2 $pattern='/^http/';  /*因为/为特殊字符*/
    3 $str=preg_replace($pattern,'jimmy',$str);
    4 echo $str;die;

    输出:

    jimmy://blog.seetiny.com/

    可以看到在已^开始的正则,只从左边第一个字符匹配,如果没匹配到,那整个匹配就是失败的

    再看$匹配字符串的结束位置

    1 $str='http://blog.seetiny.com';
    2 $pattern='/com$/';  /*因为/为特殊字符*/
    3 $str=preg_replace($pattern,'jimmy',$str);
    4 echo $str;die;

    输出:

    http://blog.seetiny.jimmy

    再看一个例子

    1 $str='http://blog.seetiny.com';
    2 $pattern='/iny$/';  /*因为/为特殊字符*/
    3 $str=preg_replace($pattern,'jimmy',$str);
    4 echo $str;die;

    输出:

    http://blog.seetiny.com

    看看同时使用^和$是什么意思呢

    1 $str='http://blog.seetiny.com';
    2 $pattern='/^iny$/';  /*因为/为特殊字符*/
    3 $str=preg_replace($pattern,'jimmy',$str);
    4 echo $str;die;

    输出:

    http://blog.seetiny.com

    改成

    1 $str='http://blog.seetiny.com';
    2 $pattern='/^http://blog.seetiny.com$/';  /*因为/为特殊字符*/
    3 $str=preg_replace($pattern,'jimmy',$str);
    4 echo $str;die;

    输出:

    jimmy

    结合例子看,用法就一目了然了,^和$用处非常多,常见的就是使用sublime编辑给每行文本开始和技术加引号,括号逗号什么的,非常方便

    例如有一堆字符串要写SQL插入到数据库

     1 85353001071
     2 85353001071
     3 85959001280
     4 81106513888
     5 81106513888
     6 81106513888
     7 81106513888
     8 81106514054
     9 81106514054
    10 811064056
    11 81106514056
    12 81106514132
    13 81106514132
    14 81106514136
    15 81106514136
    16 81106514137
    17 811065137
    18 81106514138
    19 81106514138
    20 81106514139
    21 8110651413913123
    22 83030000076
    23 83030000076
    24 83030000096
    25 83030000096
    26 83030000316123
    27 83030000483
    28 830300004854
    29 83030000489
    30 83030000533
    31 83030001323
    32 83030000610

    通过sublime非常简单的就能处理成下面的样子

     1 ("85353001071",
     2 "85353001071",
     3 "85959001280",
     4 "81106513888",
     5 "81106513888",
     6 "81106513888",
     7 "81106513888",
     8 "81106514054",
     9 "81106514054",
    10 "811064056",
    11 "81106514056",
    12 "81106514132",
    13 "81106514132",
    14 "81106514136",
    15 "81106514136",
    16 "81106514137",
    17 "811065137",
    18 "81106514138",
    19 "81106514138",
    20 "81106514139",
    21 "8110651413913123",
    22 "83030000076",
    23 "83030000076",
    24 "83030000096",
    25 "83030000096",
    26 "83030000316123",
    27 "83030000483",
    28 "830300004854",
    29 "83030000489",
    30 "83030000533",
    31 "83030001323",
    32 "83030000610")
  • 相关阅读:
    10年后方向
    nginx的配置文件server_name的意义 location意义
    java程序员应该知道的20个有用的库
    集群和分布式区别
    noVNC连接CentOS,以Web方式交付VNC远程连接
    centos7.2云主机安装桌面
    centos7.2 rabbitmq3.6.2源码部署
    Linux下打包压缩war和解压war包 zip和jar
    CentOS7.2下安装mongoDB3.2.8
    centos7 mysql5.7.17源码安装
  • 原文地址:https://www.cnblogs.com/JimmyBright/p/7205851.html
Copyright © 2020-2023  润新知