1. Match函数

使用指定的正则表达式函数对字符串惊醒查找,并以数组形式返回符合要求的字符串

原型:stringObj.match(regExp)

参数:

  • stringObj 必选项,需要去进行匹配的字符串
  • RegExp  必选项,指定的正则表达式

返回值:如果没有使用g(全局匹配)选项,则返回第一个匹配的字符串、该字符串所在位置及原始字符串组成的数组,如果使用g选项,则返回所有匹配的字符串组成的数组

示例1:   
  var str = “aaabbbcccaaabbbccc”;   
  var res = str.match(/aaa/); //没有使用g选项   
  console.log(res); //输出[ 'aaa', index: 0, input: 'aaabbbcccaaabbbccc' ] 第一个表示匹配的字符串;第二个表示匹配的字符串坐在的索引位置,从0开始计算;第三个表示原始字符串;   
  示例2:   
  var str = “aaabbbcccaaabbbccc”;   
  var res = str.match(/aaa/g); //使用g选项,全局匹配   
  console.log(res); //输出[ 'aaa', 'aaa' ] 所有匹配的字符串组成的数组 

2.exec函数

使用指定的正则表达式模式去字符串中查找匹配项,并以数组形式返回,如果未查找到则返回null

原型:regExp.exec(stringObj)

参数:

  • regExp 必选项,表示指定的正则表达式模式
  • stringObj 必选项,表示需要查找的字符串

返回值:无论有无g选项,都返回第一个匹配的字符串、该字符串所在位置及原始字符串组成的数组,但是该方法可以返回子匹配项,是match所不能及的

  示例1:

      var str = “aaabbbcccaaabbbccc”;   
      var regExp = /aaa/; //未使用g选项   
      var res = regExp .exec(str);    
      console.log(res); //输出[ 'aaa', index: 0, input: 'aaabbbcccaaabbbccc' ]   
      示例2:   
      var str = “aaabbbcccaaabbbccc”;   
      var regExp = /aaa/g; //使用g选项   
      var res = regExp .exec(str);    
      console.log(res); //输出[ 'aaa', index: 0, input: 'aaabbbcccaaabbbccc' ]   
      示例3:   
      var str = “aaabbbccc1234aaabbbccc”;   
      var regExp = /ccc([0-9]+)aaa/;   
      var res = regExp .exec(str);    
      console.log(res); //输出[ 'ccc1234aaa', '1234', index: 6, input: 'aaabbbccc1234aaabbbccc' ] 第一个表示整个正则表达式所匹配的内容;第二个表示()内容的子表达式所匹配的内容;第三个和第四个同上   
      示例4:   
      var str = “aaabbbccc1234aaabbbcccaaabbbccc5678aaabbbccc”;   
      var reg = /ccc([0-9]+)aaa/;   
      var res = reg.exec(str);   
      console.log(res); //输出同示例三,因为exec只返回第一个匹配的字符串,如果想全部返回,则需要借助while循环和g参数来实现,如下   
      var str = “aaabbbccc1234aaabbbcccaaabbbccc5678aaabbbccc”;   
      var reg = /ccc([0-9]+)aaa/g;   
      while(res = reg.exec(str)){   
        console.log(res);   
      }   
      //输出如下:   
    [ 'ccc1234aaa', '1234', index: 6, input: 'aaabbbccc1234aaabbbcccaaabbbccc5678aaabbbccc' ][ 'ccc5678aaa', '5678', index: 28, input: 'aaabbbccc1234aaabbbcccaaabbbccc5678aaabbbccc' ]   
    //使用这个方法时切记加上g选项,否则while循环将无法跳出,每次都循环第一个匹配项,导致死循环,可能卡死!  

3.test函数

原型:regExp.test(str)

参数:regExp表示正则表达式模式  stringObj表示需要进行匹配的字符串

返回值:布尔类型,匹配则返回true,否则false

示例1:   
  var str = “aaabbbcccaaabbbccc”;   
  var reg = /[a-z]+/;   
  var res = reg.test(str);   
  console.log(res); //输出true   
  示例2:   
  var str = “aaabbbcccaaabbbccc”;   
  var reg = /[0-9]+/;   
  var res = reg.test(str);   
  console.log(res); //输出false   
  //该函数一般用来检测某字符串是否符合指定的规则   

4.search函数

原型:stringObj.search(regExp)

参数:regExp表示正则表达式模式  stringObj表示需要进行匹配的字符串

返回值:返回第一个匹配的字符串所在的位置(偏移量),从0开始

示例1:   
  var str = “aaabbbcccaaabbbccc”;   
  var reg = /ccc/;   
  var res = str.search(reg);   
  console.log(res); //输出 6  

5.split函数

原型:stringObj.split([separator[, limit]])

参数:separator表示分隔符(此处也可以是正则表达式),stringObj表示需要进行匹配的字符串,limit用来限制返回数组元素的个数

返回值:返回分割后的数组

示例1:   
  var str = “aaa,bbb,ccc”;   
  var reg = /,/;   
  var res = str.split(reg);   
  console.log(res); //输出[ 'aaa', 'bbb', 'ccc' ]   
  //其实这里可以简单的写为var res = str.split(“,”);   
  示例2:   
  var str = “aaa,bbb:ccc@ddd#eee”;   
  var reg = /[,:@#]/;   
  var res = str.split(reg);   
  console.log(res); //输出[ 'aaa', 'bbb', 'ccc', 'ddd', 'eee' ] 这才是用正则的强大之处   
  示例3.   
  var str = “aaa,bbb:ccc@ddd#eee”;   
  var reg = /[,:@#]/;   
  var res = str.split(reg, 3);   
  console.log(res); //输出[ 'aaa', 'bbb', 'ccc']  

原文地址:http://www.vxueke.com/2013/04/05/307.htm

转载时必须以链接形式注明原始出处及本声明。

Nodejs正则表达式函数之match、test、exec、search、split、replace使用详解的更多相关文章

  1. Python进阶----线程基础,开启线程的方式(类和函数),线程VS进程,线程的方法,守护线程,详解互斥锁,递归锁,信号量

    Python进阶----线程基础,开启线程的方式(类和函数),线程VS进程,线程的方法,守护线程,详解互斥锁,递归锁,信号量 一丶线程的理论知识 什么是线程:    1.线程是一堆指令,是操作系统调度 ...

  2. Node.js之【正则表达式函数之match、test、exec、search、split、replace使用详解】

    1. Match函数 使用指定的正则表达式函数对字符串惊醒查找,并以数组形式返回符合要求的字符串 原型:stringObj.match(regExp) 参数: stringObj 必选项,需要去进行匹 ...

  3. (转)Python内置函数进阶之“属性(property())”详解

    原文:https://blog.csdn.net/GeekLeee/article/details/78519767 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.c ...

  4. 关于正则表达式中参数/g /m的详细分析和例子详解

    总结1:参数/g的用法 表达式加上参数g之后,表明可以进行全局匹配,注意这里"可以"的含义.我们详细叙述: 1)对于表达式对象的exec方法,不加入g,则只返回第一个匹配,无论执行 ...

  5. 正则表达式中的.*?和python中re.S参数的详解

    本章的内容主要是为讲解在正则表达式中常用的.*?和re.S! 在正则表达式中有贪婪匹配和最小匹配:如下为贪婪匹配(.*) import re match = re.search(r'PY.*', 'P ...

  6. Python开发环境Wing IDE之Search in Files工具详解

    Search in Files工具是Wing IDE中最强大的搜索选项.它支持磁盘.项目,打开编辑器,或其它文件集的多文件批量搜索.它还可以使用通配符搜索,并可以做基于正则表达式的搜索/替换. 建议用 ...

  7. python描述符(descriptor)、属性(property)、函数(类)装饰器(decorator )原理实例详解

     1.前言 Python的描述符是接触到Python核心编程中一个比较难以理解的内容,自己在学习的过程中也遇到过很多的疑惑,通过google和阅读源码,现将自己的理解和心得记录下来,也为正在为了该问题 ...

  8. SQLServer:探讨EXEC与sp_executesql的区别详解

    摘要 MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的 ...

  9. Exec msdb.dbo.sp_send_dbmail 参数详解(SQL Server 存储过程发邮件)

    转载oriency755 发布于2012-12-04 11:34:45 阅读数 6870 收藏   sp_send_dbmail [ [ @profile_name = ] 'profile_name ...

随机推荐

  1. Win10 UAP 绑定

    Compiled DataBinding in Windows Universal Applications (UAP) http://nicksnettravels.builttoroam.com/ ...

  2. 使用Visual Studio Code开发AngularJS应用

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:VSC发布之后,尤其最近刚刚更新到0.3之后,社区出现了很多介绍VSC使用的好文章.比 ...

  3. SPI-软件开发注意事项

    01 PD ,设置数据库前一定把模板设置号,命名规则规划清楚.

  4. C++Primer快速浏览笔记-类型转换

    bool b = 42; // _b is true_ int i = b; // _i has value 1_ i = 3.14; // _i has value 3_ double pi = i ...

  5. 应用程序调试工具gdb,王明学learn

    应用程序调试工具gdb学习使用 一.GDB简介 GDB 是 GNU 发布的一款功能强大的程序调试工具.GDB 主要完成下面三个方面的功能: 1.启动被调试程序. 2.让被调试的程序在指定的位置停住. ...

  6. Linux学习笔记(23) Linux备份

    1. 备份概述 Linux系统需要备份的数据有/root,/home,/var/spool/mail,/etc及日志等其他目录. 安装服务的数据需要备份,如apache需要备份的数据有配置文件.网页主 ...

  7. 定时备份mysql

    @echo offset filename=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%mysqldump -- ...

  8. python数学运算的类型转换

    类型转换 Rational类实现了有理数运算,但是,如果要把结果转为 int 或 float 怎么办? 考察整数和浮点数的转换: >>> int(12.34) 12 >> ...

  9. ez_setup.py(安装python下setuptools用)

    #!python"""Bootstrap setuptools installation If you want to use setuptools in your pa ...

  10. 自定义 ActionBar 标题与菜单中的文字样式

    自定义标题文字样式 标题样式是 ActionBar 样式的一部分,所以要先定义 ActionBar 的样式 <style name="AppTheme" parent=&qu ...