zoukankan      html  css  js  c++  java
  • 你是怎么把字符串“2016-11-16” 变为 “16/11/2016” 的?

    一、前言:

    有时候,我们需要对一些字符串中的字符进行位置变化处理。如 “2016-11-16” 需要调整为 “16/11/2016”。我们知道有很多方法可以使用,比如split()拆分成数组后在进行拼接,也可以使用正则表达式的分组机制来进行处理。下面我们就将这种方法进行实例对比:

    二、split()方法:

    split()方法主要是用于把一个字符串分割成字符串数组。
    我们分析下字符串 “2016-11-16”,可以看出这个字符串是用比较规则的,数字之间是用 “-” 符号来分隔,所以我们可以使用 split('-') (意思是:hi,字符串 “2016-11-16”,你好!我现在要把你以 “-” 的方式拆分,在解析你的过程中,凡是碰到 “-”的时候,我就要从这里切一刀,最后把切好的字符串片段都存放到一个字符串数组中去) 的方法拆分字符串。

    $(function(){
      var str = '2016-11-16',
          strArr = str.split('-'); //输出: ["2016", "11", "16"]
    
      //进行字符串拼接处理   
      str = strArr[2]+'/'+strArr[1]+'/'+strArr[0];
      console.log(str); //输出:16/11/2016
    });
    

    现在,我们发现,用上面的split()方法很好用,尤其是拆分字符串的时候。那么接下来,我们换个难一点的字符串,也就是稍微不那么规则的字符串。看看我们的拆分过程是什么样的?

    $(function(){
      var str = 'abc2016-11.16',
          strArr = str.split('-'), //输出: ["abc2016", "11.16"]
          strArr2 = strArr[0].split('abc'), //输出: ["", "2016"]
          strArr3 = strArr[1].split('.'); //输出: ["11", "16"]
    
      //进行字符串拼接处理   
      str = strArr3[1]+'/'+strArr3[0]+'/'+strArr2[1];
      console.log(str); //输出:16/11/2016
    });
    

    从上面的例子我们看出,不规则的字符串拆分,就是多次使用split()方法,只是拆分过程较为艰辛而已。但是,如果字符串 “abc2016-11.16” 中的 “abc” 不是固定的,那么你就不太好用split('abc')方法来拆分字符串了。

    三、正则表达式分组方式:

    接上面的实例,我们对应的正则表达式代码如下:

    $(function(){
      var str = '2016-11-16',
          reg = /(d{4})-(d{2})-(d{2})/g; // 正则表达式中的分组: (d{4}) 、(d{2}) 、(d{2})。
    
      str = str.replace(reg, '$3/$2/$1'); //$1、$2、$3分别表示上面的三个分组匹配结果
      console.log(str); //输出:16/11/2016
    });
    

    是不是很容易?好吧,我们再看看上面提到的那个稍微复杂一点的实例,如果用正则表达式分组来处理,代码应该是怎样的?

    $(function(){
      var str = 'abc2016-11.16',
          reg = /[a-z]+(d{4})-(d{2}).(d{2})/g;
    
      str = str.replace(reg, '$3/$2/$1');
      console.log(str); //输出:16/11/2016
    });
    

    你会发现用正则表达式分组匹配结果的形式,在处理一些字符串较为复杂但依然有规可循的情况下,是非常有效的。当然,你可以发挥更多的想象空间,创造更为复杂的字符串,使用正则表达式分组的方式试一下吧!

  • 相关阅读:
    [转]Object Tracking using OpenCV (C++/Python)(使用OpenCV进行目标跟踪)
    [转]PIL、Pillow安装使用方法
    [转]痞子衡嵌入式:飞思卡尔Kinetis开发板OpenSDA调试器那些事(上)
    如何选择开源许可证?
    年复一年
    [转]TLD目标跟踪算法
    [转]pycharm中将ui文件转换成py文件
    ps矫正倾斜的扫描件内容
    ORM增删改查
    ORM配置
  • 原文地址:https://www.cnblogs.com/yuanbo88/p/6070486.html
Copyright © 2011-2022 走看看