zoukankan      html  css  js  c++  java
  • 关于正则表达式中^和$

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

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

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

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

    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")
  • 相关阅读:
    数据库备份与还原
    启明星产品与微软Active Directory活动目录集成说明
    启明星请假系统里,计算工作日的实现
    启明星会议室预定系统Outlook版开始支持Exchange2013与Office365版
    Jquery Mobile实例--利用优酷JSON接口读取视频数据
    高性能且线程安全的两种格式化日期方式
    将数列唯一值化后再求中值的效率比较 第一方案胜出,加索引后在近两百万数据中查出中值耗时0.176秒
    Oracle WITH 语句 语法
    新三种求数列中值SQL之效率再比拼
    rank,dense_rank和row_number函数区别
  • 原文地址:https://www.cnblogs.com/JimmyBright/p/7205851.html
Copyright © 2011-2022 走看看