正则表达式Regular Expression (RegExp)详解

正则表达式,又称正规表示式、正规表示法、正规表达式、规则表达式、常规表示法(英语:Regular Expression,在代码中常简写为regex、regexp或RE)。

正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。

一、字符类

1、字符类:可以匹配他所包含的任意字符

eg:/[abc]/和字母"a"、"b"、"c"中的任意一个匹配

2、否定字符类: 通过"^"字符定义否定字符类,他匹配所有不包含在方括号内的字符。定义否定字符类时,将一个"^"符号作为左括号内的第一个字符。

eg:/[^abc]/匹配"a"、"b"、"c"之外的所有字符。

3、\s : 匹配的是空格符、制表符和其他Unicode空白符;

.  :  除换行符和其他Unicode行终止符之外的任意字符。

二、重复:

1、{n,m} 匹配前一项至少n次,但不能超过m次;

2、{n,} 匹配前一项n次或者更多次;

3、{n} 匹配前一项n次;

4、? 匹配前一项0次或者1次;

5、*  匹配前一项0次或者多次;

6、+ 匹配前一项1次或者多次 .

PS:非贪婪性重复---在待匹配的字符后面跟随一个问号即可。 "??" "+?"  "*?"

三、选择、分组和引用

1、"|" 分割供选择的字符

eg:/ab|cd|ef/ 可以匹配字符串"ab"、也可以匹配字符串"cd"、还可以匹配字符串"ef"

2、"()":圆括号的作用:a.把单独的项组合成子表达式;b.在完整的模式中定义子模式;c.允许在同一正则表达式的后部引用前面的子表达式。

3、"(?:" 和 ")"进行分组,但不记忆与改组相匹配的字符

四、指定匹配位置:

1、匹配发生的合理位置,正则表达式的锚。

2、"^" 匹配字符串的开始

3、"$" 匹配字符串的结束

4、任意正则表达式都可以作为锚点。如果在符号"(?="和")"之间加入一个表达式,它就是一个先行断言。

5、负先行断言"(?!"和")"

五、修饰符:

1、i 不区分大小写

2、g 全局匹配

3、m 多行中执行匹配

六、RegExp方法

-------  String 方法  -------

1、search() 返回第一个与之匹配的字符串的位置;

2、repalce() 执行检索和替换操作

如果正则表达式设置了修饰符g,那么源字符串中所有与模式匹配的字符串都将替换成第二个参数指定的字符串;如果不带修饰符g,则只替换匹配的第一个子串。

3、match() 返回由匹配结果组成的数组

-------  RegExp方法 -------

4、exec()

5、test()

=======================    一些常用的正则表达式     ========================

1、删除首尾行的空白字符(包括空格符、制表符、其他Unicode空白符)

var pattern = /(^\s*)|(\s*$)/g ;
"  abc  def  ".replace(pattern,""); //执行结果是:"abc  def"
2、强密码:密码为8-12位,并且大写字母、小写字母、数字、特殊字符都包含

var strongRegExp = /^(?=.{8,12})(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.*\W).*$/g ;
3、弱密码:密码为7-12位,并且包含大写字母、小写字母、数字中任意两项,且不包含特殊字符

var mediumRegExp = /^(?=.{7,12})(((?=.*[A-Z])(?=.*[a-z]))|((?=.*[A-Z])(?=.*[1-9]))|((?=.*[a-z])(?=.*[1-9]))).*$/g ;

(0)

相关推荐

  • node+express+jade制作简单网站指南

    1.建立工程文件夹:my_jade 2.下载express和jade包到本地.我个人不喜欢下载成全局的,我喜欢下到工程文件夹中去. 3.建立相关的文件夹和文件. index.js: style.css gys.jade代码: index.jade: layout.jade app.js 运行app.js:node app.js; 在浏览器中预览: 在看一个不使用页面布局的例子: 修改index.js 修改app.js 运行app.js在浏览器中预览: 单击提交 会触发ajax. .本文就先到这里

  • DevExpress之SplashScreen用法实例

    本文实例展示了DevExpress中SplashScreen的用法,对于C#初学者来说有一定的参考借鉴价值,具体用法如下: 关键代码部分如下: using DevExpress.XtraSplashScreen; using System; namespace DevExpressUtilHelpV3 { /// <summary> /// 基于.NET 3.0的 SplashScreen工具类 /// </summary> public static class SplashSc

  • express的中间件bodyParser详解

    bodyParser用于解析客户端请求的body中的内容,内部使用JSON编码处理,url编码处理以及对于文件的上传处理. 下面是一个文件上传的例子. 建立一个1.html页面 复制代码 代码如下: <!DOCTYPE html>  <html>  <head lang="en">      <meta charset="UTF-8">      <title>向服务器上传文件</title>

  • DevExpress之ChartControl用法实例总结

    DevExpress中的ChartControl顾名思义就是数据基于图表展示,其关键在于Series上的处理.本文实例展示了ChartControl的用法,具体内容如下: 主要功能代码部分如下: using System; using System.Drawing; using DevExpress.XtraCharts; namespace DevExpressUtilHelpV3 { public static class ChartToolV3 { /// <summary> /// 创

  • node+express+ejs制作简单页面上手指南

    1.建立工程文件夹my_ejs. 2.首先利用npm install express和npm install ejs 下载这两个家伙.至于要不要设置成全局的,看习惯,我习惯性的下载到本项目中的文件夹中my_ejs. 然后建立相应的文件: index.js: form.ejs: index.ejs app.js: 开始运行app.js node app.js,然后再浏览器端访问:localhost:1337 单击发表文章: 点击发表,跳转到首页. 好了到此为止,一个简易的"网站"算是出来

  • NodeJS框架Express的模板视图机制分析

    模板引擎 Express支持许多模板引擎,常用的有: haml 的实现Haml haml.js 接替者,同时也是Express的默认模板引擎Jade 嵌入JavaScript模板EJS 基于CoffeeScript的模板引擎CoffeeKup 的NodeJS版本jQuery模板引擎 视图渲染(view randering) 视图的文件名默认需遵循"<name>.<engine>"的形式,这里<engine>是要被加载的模块的名字.比如视图layout

  • C#之Expression表达式树实例

    本文实例讲述了C#之Expression表达式树,分享给大家供大家参考.具体实现方法如下: 表达式树表示树状数据结构的代码,树状结构中的每个节点都是一个表达式,例如一个方法调用或类似 x < y 的二元运算 1.利用 Lambda 表达式创建表达式树 复制代码 代码如下: Expression<Func<int, int, int, int>> expr = (x, y, z) => (x + y) / z; 2.编译表达式树,该方法将表达式树表示的代码编译成一个可执行

  • express的中间件cookieParser详解

    cookieParser中间件用于获取web浏览器发送的cookie中的内容.在使用了cookieParser中间件后, 代表客户端请求的htto.IncomingMessage对象就具有了一个cookies属性,该属性之为一个对象的数组, 其中存放了所有web浏览器发送的cookie,每一个cookie为cookies属性值数组中的一个对象. index.html代码: 复制代码 代码如下: <!DOCTYPE html>  <html>  <head lang="

  • 在WIN7下安装和配置SQL Server 2005 Express Edition(精简版)

    折腾了一下午,终于把SQL Server 2005 Express Edition装好,鉴于出现了各种问题,所以把过程写下来. 首先,下载两个文件: ①SQL Server 2005 Express Edition 下载地址:http://files.jb51.net/file_images/article/201501/2015010313472645.aspx ②SQLServer2005_SSMSEE.msi 下载地址:http://files.jb51.net/file_images/a

  • 在 Express 中使用模板引擎

    需要在应用中进行如下设置才能让 Express 渲染模板文件: views, 放模板文件的目录,比如: app.set('views', './views') view engine, 模板引擎,比如: app.set('view engine', 'jade') 然后安装相应的模板引擎 npm 软件包. $ npm install jade --save 和 Express 兼容的模板引擎,比如 Jade,通过 res.render() 调用其导出方法 __express(filePath,

  • DevExpress之TreeList用法实例总结

    本文实例总结了DevExpress之TreeList用法,希望对大家学习C#程序设计起到一定的帮助作用.具体实例如下: using System; using System.Collections.Generic; using System.Drawing; using System.Windows.Forms; using DevExpress.XtraBars; using DevExpress.XtraTreeList; using DevExpress.XtraTreeList.Node

  • Nodejs+express+html5 实现拖拽上传

    一.前言 文件上传是一个比较常见的功能,传统的选择方式的上传比较麻烦,需要先点击上传按钮,然后再找到文件的路径,然后上传.给用户体验带来很大问题.html5开始支持拖拽上传的需要的api.nodejs也是一个最近越来越流行的技术,这也是自己第一次接触nodejs,在nodejs开发中,最常用的开发框架之一是expess,它是一个类似mvc模式的框架.结合html5.nodejs express实现了拖拽上传的功能. 二.基础知识普及 1.NodeJs基础知识 nodejs简单来说就是一个可以让j

随机推荐