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


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

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

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

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

    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")
  • 相关阅读:
    Android布局与事件
    android 开发中共享全局数据Application的类
    从Android界面开发谈起【转】
    HttpClient java
    关于整合S&K框架的一些个小注意
    批处理执行多条语句
    Atitit. 软件设计 模式 变量 方法 命名最佳实践 vp820 attilax总结命名表大全
    atitit.软件设计模式大的总结attialx总结
    Atitit.软件开发的最终的设计 dsl化,ast化(建立ast, 解析执行ast)
    atitit。流程图的设计与制作 attilax 总结
  • 原文地址:https://www.cnblogs.com/JimmyBright/p/7205851.html
Copyright © 2020-2023  润新知