javascript正则表达式学习之位置匹配_正则表达式

来源:脚本之家  责任编辑:小易  

/^ZL\\d{8}|\\d{12}$/匹配一个字符串仅能为这样的字符,不能有其他字符。指定匹配必须出现在字符串的开头或行的开头。指定匹配必须出现在以下位置:字符串结尾、字符串结尾的 \\n 之前或行的结尾www.zgxue.com防采集请勿采集本网。

一、前言

定义变量str来表示要匹配的字符串 var reg=weight=(\\d+),words=(\\w+)/g;var arrobj;每次匹配的临时存储数组 var arrval=new Array();最后结果的存储数组 while((arrobj=reg.exec(str))!null) { arrval.

正则表达式是匹配模式,要么是匹配字符,要么匹配位置。

var reg=\\d{2}[A-Z]\\d*,?g;var str=\"04A11111,04A11123,01A04704…;str.match(reg)

其实在开发中很少用到匹配位置,本篇文章主要包含:

\\'\\\\\\*\\?这个只能匹配一个字符 输入2个\\\\&\\^\\$\\当然是false [^\\[\\|\\\\\"\\\\+\\\\\\^[^\\[\\|\\&\\$\\^\\*\\'

二、什么是位置

abc{0,}/它表示匹配 0个或多个c abc{2}/只能匹配两个cc 也就是 abcc abc{2,}/可以匹配2个到两个c以上,当然abcccc也能匹配。abc){2}/它可以匹配2个abc {n} 这个操作符它是针对前面一个字符来的

位置:相邻字符之间的位置。

/CDrag=([^;这段正则表达式 匹配这样的字符串: CDrag=abc;A CDrag=defg?B CDrag=hijk:C CDrag=abc;CDrag=defg?CDrag=hijk: CDrag=abc CDrag=defg CDrag=hijk [^;表示不包含;的字符串 表示以?或

三、如何匹配位置

在ES5中,共有6个锚:^, $, \b, \B, (?=p), (?!p)

可视化形式:

RegExp:/^$\b\B(?=a)(?!b)/g

3.1 ^和$

^(脱字符)匹配开头,在多行匹配中匹配行开头。

$(美元符)匹配结尾,在多行匹配中匹配行结尾。

比如:我们把字符串的开头和结尾用#替换(位置可以替换成字符的):

var result = "hello".replace(/^|$/g, '#');console.log(result);// "#hello#"

多行匹配模式(有修饰符m)时,二者是行的概念,我们需要注意:

var result = "I\nlove\njavascript".replace(/^|$/gm, '#');console.log(result);// #I#// #love#// #javascript#

3.2 \b和\B

\b是单词边界,具体就是\w和\W之间的位置,也包括\w与^之间的位置,和\w和$之间的位置。

比如考察文件名"[JS] Lesson_01.mp4"中的\b,如下:

var result = "[JS] Lesson_01.mp4".replace(/\b/g, '#');console.log(result);// "[#JS#] #Lesson_01#.#mp4#"

首先,我们知道\w是字符组[0-9a-zA-Z]的简写,即使字母数字或者下划线中任何一个字符。而\W是字符组[^0-9a-zA-Z]的简写,即\W是\w以外的任何一个字符。

我们再来看#是怎么来的:

第 1 个,两边字符是 "[" 与 "J",是 \W 与 \w 之间的位置。

第 2 个,两边字符是 "S" 与 "]",也就是 \w 与 \W 之间的位置。

第 3 个,两边字符是空格与 "L",也就是 \W 与 \w 之间的位置。

第 4 个,两边字符是 "1" 与 ".",也就是 \w 与 \W 之间的位置。

第 5 个,两边字符是 "." 与 "m",也就是 \W 与 \w之间的位置。

第 6 个,位于结尾,前面的字符 "4" 是 \w,即 \w 与 $ 之间的位置。

知道了\b概念后,那\B就好理解了,\b是单词边界,\B是非单词边界

var result = "[JS] Lesson_01.mp4".replace(/\B/g, '#');console.log(result);// "#[J#S]# L#e#s#s#o#n#_#0#1.m#p#4"

3.3 (?=p) 和 (?!p)

(?=p)其中p是一个子模式,即 p前面的位置 (该位置后面的字符要匹配p)

比如:(?=e),表示的是e字符前面的位置;

var result = "hello".replace(/(?=l)/g, '#');console.log(result);// "he#l#lo"

而(?!p)就是(?=p)的反面意思

var result = "hello".replace(/(?!l)/g, '#');console.log(result);// "#h#ell#o#"

二者的学名分别是 positive lookahead 和 negative lookahead。

中文翻译分别是 正向先行断言负向先行断言

ES5 之后的版本,会支持 positive lookbehind 和 negative lookbehind。

具体是 (?<=p) 和 (?<!p)。

四、位置特性

对于位置的理解,我们可以累计额成空字符""。

比如"hello"字符串等价于如下形式:

"hello" == "" + "h" + "" + "e" + "" + "l" + "" + "l" + "" + "o" + "";

也等价于

"hello" == "" + "" + "hello"

因此,把 /^hello$/ 写成 /^^hello$$$/,是没有任何问题的:

var result = /^^hello$$$/.test("hello");console.log(result);// true

也就是说,字符之间的位置,可以写成多个。

注:把 位置 理解 空字符 ,是对位置非常有效的理解方式

五、相关案例

5.1不匹配任何东西的正则

/.^/

正则要求 只有一个字符,但是该字符后面是开头 ,而这样的字符串是不存在的。

5.2数字的千分位分隔符表示法

比如吧12345678,变成12,345,678。

分析:那就是需要把相应的位置替换成","

5.2.1弄出来最后一个逗号

正则:/(?=\d{3}$)/

var result = "12345678".replace(/(?=\d{3}$)/g, ',')console.log(result);// 12345,678

其中(?=\d{3}$)匹配\d{3}$前面的位置。而\d{3}$匹配的是目标字符串最后那3为数字。

5.2.2弄出来多有逗号

因为逗号的出现的位置,要求后边3个数字一组,也就是\d{3}至少出现1次。

可以使用量词 + :

var result = "12345678".replace(/(?=(\d{3})+$)/g, ',')console.log(result);// 12,345,678

5.2.3匹配其余案例

写完正则后,是需要举个别案例来验证的,就会发现问题:

var result = "123456789".replace(/(?=(\d{3})+$)/g, ',')console.log(result);// ,123,456,789

上面的正则,仅仅是表示把从结尾向前数,一旦是3的倍数买酒吧前面的位置替换为逗号。

还需要要求:匹配的这个位置不能是开头。

我们知道开头的匹配是使用^,但是不是开头怎么整?

使用(?!^)

var regex = /(?!^)(?=(\d{3})+$)/g;var result = "12345678".replace(regex, ',')console.log(result);// "12,345,678"result = "123456789".replace(regex, ',');console.log(result);// "123,456,789"

5.2.4支持其他形式

如果要把 "12345678 123456789" 替换成 "12,345,678 123,456,789"。

此时我们需要修改正则,把里面的开头 ^ 和结尾 $,修改成 \b:

var string = "12345678 123456789",regex = /(?!\b)(?=(\d{3})+\b)/g;var result = string.replace(regex, ',')console.log(result);// "12,345,678 123,456,789"

其中(?!\b)怎么理解?

要求是当前的一个位置,但不是\b前面的位置,其实(?!\b)说的是\B。

因此最终正则变成了:/\B(?=(\d{3})+\b)/g。

可视化形式:

RegExp:/\B(?=(\d{3})+\b)/g

5.2.5货币格式化

千分符表示法一个常见的应用就是货币格式化。

把这个字符串:

格式化:

$ 1888.00

实现:

function format (num) {return num.toFixed(2).replace(/\B(?=(\d{3})+\b)/g, ",").replace(/^/, "$ ");};console.log( format(1888) );// "$ 1,888.00"

5.3验证密码的问题

密码长度6-12,由数字,小写字母,大写字母组成,但必须至少包括2种字符。

写成多个正则来判断,比较容易,但是要写成一个正则就比较困难。

来看看我们对于位置的理解是否深刻。

5.3.1简化

暂时不考虑"必须至少包含2种字符"这个条件,可以容易写出:

var regex = /^[0-9A-Za-z]{6,12}$/;

5.3.2判断是否包含有某一种字符

假设,要求我们必须包含数字,怎么整?此时我们可以使用(?=.*[0-9])来实现。

正则变成:

var regex = /(?=.*[0-9])^[0-9A-Za-z]{6,12}$/;

5.3.3同时包含具体两种字符

比如同时包含数字和小写字母,可以使用(?=.*[0-9])(?=.*[a-z])来实现。

正则变成:

var regex = /(?=.*[0-9])(?=.*[a-z])^[0-9A-Za-z]{6,12}$/;

5.3.3具体实现

把原题变成下列几种情况:

1、同时包含数字和小写字母;

2、同时包含数字和大写字母;

3、同时包含小写字母和大写字母;

4、同时包含数字,小写字母和大写字母。

以上的4中情况是 的关系(实际上,第四条可以不用)。

最终答案:

var regex = /((?=.*[0-9])(?=.*[a-z])|(?=.*[0-9])(?=.*[A-Z])|(?=.*[a-z])(?=.*[AZ]))^[0-9A-Za-z]{6,12}$/;console.log( regex.test("1234567") ); // false 全是数字console.log( regex.test("abcdef") ); // false 全是小写字母console.log( regex.test("ABCDEFGH") ); // false 全是大写字母console.log( regex.test("ab23C") ); // false 不足6位console.log( regex.test("ABCDEF234") ); // true 大写字母和数字console.log( regex.test("abcdEF234") ); // true 三者都有

可视化形式:

RegExp:/((?=.*[0-9])(?=.*[a-z])|(?=.*[0-9])(?=.*[A-Z])|(?=.*[a-z])(?=.*[AZ]))^[ 0-9A-Za-z]{6,12}$/

分析:

上面正则看起来好复杂,只需要理解第二步,/(?=.*[0-9])^[0-9A-Za-z]{6,12}$/;

对于这个正则,我们需要明白(?=.*[0-9])^这个;

分开来看就是(?=.*[0-9]) 和 ^。

表示开头前面还有个位置(当然也是开头,即同一个位置,想想之前的空字符类比)。

(?=.*[0-9]) 表示该位置后面的字符匹配。

.*[0-9],即,有任何多个任意字符,后面再跟个数字。

翻译成大白话,就是接下来的字符,必须包含个数字。

5.3.4另外一种解法

“至少包含两种字符”的意思就是说,不能全部都是数字,也不能全部都是小写字母,也不能全部都是大写字母。

那么要求“不能全部都是数字”,怎么做呢? (?!p) 出马!

对应的正则:

var regex = /(?!^[0-9]{6,12}$)^[0-9A-Za-z]{6,12}$/;

三种“都不能”呢?

最终答案是:

var regex = /(?!^[0-9]{6,12}$)(?!^[a-z]{6,12}$)(?!^[A-Z]{6,12}$)^[0-9A-Za-z]{6,12}$/;console.log( regex.test("1234567") ); // false 全是数字console.log( regex.test("abcdef") ); // false 全是小写字母console.log( regex.test("ABCDEFGH") ); // false 全是大写字母console.log( regex.test("ab23C") ); // false 不足6位console.log( regex.test("ABCDEF234") ); // true 大写字母和数字console.log( regex.test("abcdEF234") ); // true 三者都有

可视化形式:

RegExp:/(?!^[0-9]{6,12}$)(?!^[a-z]{6,12}$)(?!^[A-Z]{6,12}$)^[0-9A-Za-z]{6,12}$/;

总结

以上所述是小编给大家介绍的javascript正则表达式学习之位置匹配,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对真格学网网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

{n}:例如:abc{2},表示C连续出现2个,可以和 abcc 匹配,也和 abcccc匹配。但不能和abc匹配。捕获结果都是abcc.{n,}:例如:abc{2,},表示c至少连续出现2个,可以和abcc 匹配,也可以和 abccccc中的所有c匹配,匹配结果但不能和abc匹配。捕获结果不同,adcc捕获结果是adcc,adccccc捕获结果是adccccc,取匹配值的最大值。{n,}:一般会是{n,m}这么写的,表示,至少连续出现N个,至多出现M个。你可以下载正则表达式的工具下来,多练习就会。百度正则表达式工具就可以,MTracer工具可以查看到捕获结果,在线工具网址:http://tk-zhang.javaeye.com/blog/466343内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • js 正则表达式的位置匹配
  • js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析
  • js正则表达式惰性匹配和贪婪匹配用法分析
  • js匹配网址url的正则表达式集合
  • js正则表达式匹配检测各种数值类型(数字验证)
  • string字符串匹配javascript 正则表达式
  • javascript正则表达式匹配 div style标签
  • 详解javascript正则表达式之分组匹配及反向引用
  • 正则表达式(regex)错误使用导致功能漏洞分析
  • javascript validation for email(正则表达式) 英文翻译
  • js:正则将首字单词转成大写
  • 正则表达式匹配 非xxx的行
  • asp 正则 过滤重复字符串的代码
  • js正则表达式替换url参数的方法
  • pjblog的ubbcodeasp文件
  • js只能输入数字或数字和字母等的正则表达式
  • 密码强度的正则表达式两种方案js总结篇
  • 正则表达式断言、巡视(assertions)、正向断言、反向断言介绍
  • javascript的正则表达式
  • JavaScript正则表达式
  • javascript正则表达式
  • javascript正则表达式
  • javascript 正则表达式
  • javascript正则表达式
  • javascript 正则表达式
  • javascript的正则表达式
  • 正则表达式 javascript
  • 正则表达式 javascript
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全javascriptasp.netphp编程ajax相关正则表达式asp编程jsp编程编程10000问css/htmlflex脚本加解密web2.0xml/rss网页编辑器相关技巧安全相关网页播放器其它综合dart首页正则表达式js 正则表达式的位置匹配js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析js正则表达式惰性匹配和贪婪匹配用法分析js匹配网址url的正则表达式集合js正则表达式匹配检测各种数值类型(数字验证)string字符串匹配javascript 正则表达式javascript正则表达式匹配 div style标签详解javascript正则表达式之分组匹配及反向引用正则表达式(regex)错误使用导致功能漏洞分析javascript validation for email(正则表达式) 英文翻译js:正则将首字单词转成大写正则表达式匹配 非xxx的行asp 正则 过滤重复字符串的代码js正则表达式替换url参数的方法pjblog的ubbcodeasp文件js只能输入数字或数字和字母等的正则表达式正则表达式断言、巡视(assertions)、正向断言、反向断言介绍java 正则表达式详解比较正宗的验证邮箱的正则表达式正则表达式匹配任意字符(包括换最新手机号码、电话号码正则表达javascript 手机号码正则表达式验js利用正则配合replace替换指定字正则表达式匹配不包含某些字符串正则中需要转义的特殊字符小结js正则函数match、exec、test、s最全的常用正则表达式大全——包js 小数验证函数代码(基于正则)好东西,老外用正则表达式写的html分离函求个简单正则eclipse使用正则表达式快速修改代码的方法正则应用之 日期正则表达式ubb代码转换为html正则表达式实现字符串每4位后自动加空格效正则表达式不包含align该怎么写用javascript实现全局替换,解决$等特殊符java使用正则表达式对注册页面进行验证功
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved