`
javatoyou
  • 浏览: 1016665 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

温故知新 javascript 正则表达式

 
阅读更多
很长时间没看 正则表达式了,碰巧今天用到,温故知新了一把 看书学习吧
50% 的举一反三练习中的原创。
一 javascript正则表达式的基本知识

1 javascript 正则对象创建 和用法

声明javascript 正则表达式

var reCat = new RegExp("cat");
你也可以
var reCat = /cat/; //Perl 风格 (推荐)

2 学习最常用的 test exec match searchreplacesplit 6个方法

1) test检查指定的字符串是否存在

var data = "123123";
var reCat = /123/gi;
alert(reCat.test(data)); //true

//检查字符是否存在g 继续往下走i 不区分大小写

2) exec 返回查询值

var data = "123123,213,12312,312,3,Cat,cat,dsfsdfs,";
var reCat = /cat/i;
alert(reCat.exec(data)); //Cat

3)match得到查询数组

var data = "123123,213,12312,312,3,Cat,cat,dsfsdfs,";
var reCat = /cat/gi;
var arrMactches = data.match(reCat)

for (var i=0;i < arrMactches.length ; i++)
{
alert(arrMactches[i]); //Cat cat
}

4) search返回搜索位置类似于indexof

var data = "123123,213,12312,312,3,Cat,cat,dsfsdfs,";
var reCat = /cat/gi;
alert(data.search(reCat)); //23


5) replace替换字符利用正则替换

var data = "123123,213,12312,312,3,Cat,cat,dsfsdfs,";
var reCat = /cat/gi;
alert(data.replace(reCat,"libinqq"));

6)split 利用正则分割数组

var data = "123123,213,12312,312,3,Cat,cat,dsfsdfs,";
var reCat = //,/;
var arrdata = data.split(reCat);

for (var i = 0; i < arrdata.length; i++)
{
alert(arrdata[i]);
}

3学习下简单类 负向类范围类组合类

//简单类
var data = "1libinqq,2libinqq,3libinqq,4libinqq";
var reCat = /[123]libinqq/gi;
var arrdata = data.match(reCat);

for (var i = 0; i < arrdata.length; i++)
{
alert(arrdata[i]); // 1libinqq2libinqq 3libinqq
}

//负向类
var data = "alibinqq,1libinqq,2libinqq,3libinqq,4libinqq";///u0062cf
var reCat = /[^a123]libinqq/gi;
var arrdata = data.match(reCat);

for (var i = 0; i < arrdata.length; i++)
{
alert(arrdata[i]); //4libinqq
}

//范围类
var data = "libinqq1,libinqq2,libinqq3,libinqq4,libinqq5";///u0062cf
var reCat = /libinqq[2-3]/gi;
var arrdata = data.match(reCat);

for (var i = 0; i < arrdata.length; i++)
{
alert(arrdata[i]); // libinqq2 libinqq3
}

//组合类
var data = "a,b,c,w,1,2,3,5";///u0062cf
var reCat = /[a-q1-4/n]/gi;
var arrdata = data.match(reCat);

for (var i = 0; i < arrdata.length; i++)
{
alert(arrdata[i]); // a b c 1 2 3
}


这些都是 js正则 最基本的使用方法,看不会的请复制到笔记本练习下,看会了再往下面看。
二 javascript 正则表达式是分组知识
1) 简单分组
Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式简单的分组
举例我们要查找字符串MouseMouse

varreCat=/MouseMouse/gi;

尽管这是可以的,但是有点浪费。如果不知道Mouse在字符串中到底出现几次时该怎么办,如果重复多次呢。
varreCat=/(mouse){2}/gi;括号的意思列Mouse将在一行连续出现2次。

*/

vardata="Ah-mousemouse";
varreCat=/(mouse){2}/gi;
vararrdata=data.match(reCat);

for(vari=0;i<arrdata.length;i++)
{
alert(arrdata[i]);
}


//-->
</script>
2 复杂分组
Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式复杂的分组
?零次或一次
*零次或多次
+最少一次或多次
*/

vardata="bbbadabaddadaa";
varreCat=/([bd]ad?)/gi;//匹配出badabaddad
vararrdata=data.match(reCat);

for(vari=0;i<arrdata.length;i++)
{
alert(arrdata[i]);
}


//同时也不介意将分组放在分组中间
//varre=/(mom(anddad)?)/;匹配出mom或monanddaa
//-->
</script>

3 反向引用

Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式反向引用*/

varsToMatch="#123456789";
varreNumbers=/#(/d+)/;
reNumbers.test(sToMatch);
alert(RegExp.$
1);

/*
这个例子尝试匹配后面跟着几个或多个数字的镑符合,并对数字进行分组
以存储他们。在调用test方法后,所有的反向引用都保存到了RegExp构造函数中
从RegExp.$1(它保存了第一个反向引用)开始,如果还有第二个反向引用,就是
RegExp.$2,如果还有第三个反向引用存在,就是RegExp.$3.依此类推。因为该组
匹配了“123456780”,所以RegExp.$1中就存储了这个字符串。

*/


varsToChange="12345678";
varreMatch=/(/d{4})(/d{4})/;
varsNew=sToChange.replace(reMatch,"$2$1");
alert(sNew);

/*
在这个例子中,正则表达式有两个分组,每一个分组有四个数字。在replace()方法的第二个参数
中,$2等同于“5678”,而$1等同于“1234”,对应于它们在表达式中的出现顺序。
*/

//-->
</script>

4 候选

Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式候选*/
varsToMatch1="red";
varsToMatch2="black";
varreRed=/red/;
varreBlack=/black/;

alert(reRed.test(sToMatch1)
||reBlack.test(sToMatch1));
alert(reRed.test(sToMatch2)
||reBlack.test(sToMatch2));

/*
这虽然能完成任务,但是十分沉长,还有另一种方式就是正则表达式的候选操作符。
*/

varsToMatch1="red";
varsToMatch2="black";
varreRedOrBlack=/(red|black)/;
alert(reRedOrBlack.test(sToMatch1));
alert(reRedOrBlack.test(sToMatch2));

//-->
</script>

5 非捕获性分组

Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式非捕获性分组

如果要创建一个非捕获性分组,只要在左括号的后面加上一个问号和一个紧跟的冒号:
*/

varsToMatch="#123456789";
varreNumbers=/#(?:/d+)/;
reNumbers.test(sToMatch);
alert(RegExp.$
1);

/*
这个例子的最后一行代码输出一个空字符串,因为该组是非捕获性的,
*/

varsToMatch="#123456789";
varreNumbers=/#(?:/d+)/;
alert(sToMatch.replace(reNumbers,
"abcd$1"));

/*
正因如此,replace()方法就不能通过RegExp.$x变量来使用任何反向引用,这段代码
输出的“abcd$1”而不是abcd123456789,因为$1在这里并不被看成是一个反向引用。
*/
//-->
</script>

6 前瞻

Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式前瞻
前瞻就和它名字一样,它告诉正则表达式运算器向前看一些字符而不是移动位置
*/


varsToMatch1="bedroom";
varsToMatch2="bedding";
varreBed=/bed(?=room)/;
alert(reBed.test(sToMatch1));
//true
alert(reBed.test(sToMatch2));//false

//负向前瞻

varsToMatch1="bedroom";
varsToMatch2="bedding";
varreBed=/bed(?!room)/;
alert(reBed.test(sToMatch1));
//false
alert(reBed.test(sToMatch2));//true
//-->
</script>

7 边界

Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式边界
^行开头
$行结尾
/b单词的边界
/B非单词的边界
*/

varsToMatch="Importantwordisthelastone.";
varreLastWord=/(/w+)/.$/;
reLastWord.test(sToMatch);
alert(RegExp.$
1);//one

/*
假如想查找一个单词,但要它只出现在行尾,则可以使用美元符号($)来表示它:
*/



varsToMatch="Importantwordisthelastone.";
varreLastWord=/^(/w+)/;
reLastWord.test(sToMatch);
alert(RegExp.$
1);//Important

/*
在这个例子中,正则表达式查找行起始位置后的一个或多个单词字符。如果遇到非单词字符
匹配停止,返回Important。这个例子也可以用单词边界实现。
*/

varsToMatch="Importantwordisthelastone.";
varreLastWord=/^(.+?)/b/;
reLastWord.test(sToMatch);
alert(RegExp.$
1);//Important

/*
这里,正则表达式用惰性量词来制定在单词边界之前可以出现任何字符,且可以出现一次或
多次(如果使用贪婪性量词,表达式就匹配整个字符串)。
*/

vardata="Firstsecondthindfourthfifthsixth";
varreCat=//b(/S+?)/b/g;
vararrdata=data.match(reCat);

for(vari=0;i<arrdata.length;i++)
{
alert(arrdata[i]);
}

/*
使用单词边界可以方便地从字符串中抽取单词。
*/
//-->
</script>

8 多行模式

Code
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><scriptlanguage="JavaScript">
<!--
/*正则表达式多行模式

要制定多行模式,只要在正则表达式想要匹配的行末的一个单词
*/

vardata="Firstsecond/nthindfourth/nfifthsixth";
varreCat=/(/w+)$/g;
vararrdata=data.match(reCat);

for(vari=0;i<arrdata.length;i++)
{
alert(arrdata[i]);
}

/*
上面只返回一个单词sixth,因为换行符阻挡了匹配,只能匹配行末的一个单词,
当然也可以使用split()方法将字符串分割成数组,但就得对每一行进行单独匹配。

以前不好好看书经常半吊子,看一半就仍了,导致用了好多split,其实很简单如下面
例子只需要m参数进行多行匹配。

*/
vardata="Firstsecond/nthindfourth/nfifthsixth";
varreCat=/(/w+)$/gm;
vararrdata=data.match(reCat);

for(vari=0;i<arrdata.length;i++)
{
alert(arrdata[i]);
}


//-->
</script>

至此结束,这些都是 javascript 正则表达式的基本方法,如果你看会了看复杂的正则你会有豁然开朗的感觉。
另外 我知道有些人很懒(包括我),所以正则分组的例子的我特此打包欢迎下载学习 js正则分组

其实还有 断言 回逆 等 3~5种的正则,一看表12点了,又要举例子又要翻译,吐血,还是算了,我还是春梦了无痕吧。

分享到:
评论

相关推荐

    Rain Water Algorithm雨水优化算法附matlab代码.zip

    1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    基于springboot+vue的房屋租赁出售系统

    提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

    杭电-[数据结构(c语言版)]复习题纲杭州电子科技大学.pdf

    杭州电子科技大学,期末考试资料,计算机专业期末考试试卷,试卷及答案,数据结构。

    年医院医生个人工作总结.docx

    工作总结,新年计划,岗位总结,工作汇报,个人总结,述职报告,范文下载,新年总结,新建计划。

    阿里巴巴笔试题目.docx

    校园招聘笔试题目及答案

    顺从宗族联动机器人matlab代码.zip

    1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    基于Python的图像阴影检测与去除源码(高分期末大作业项目).zip

    基于Python的图像阴影检测与去除源码(高分期末大作业项目).zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 基于Python的图像阴影检测与去除源码(高分期末大作业项目).zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 基于Python的图像阴影检测与去除源码(高分期末大作业项目).zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 基于Python的图像阴影检测与去除源码(高分期末大作业项目).zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 基于Python的图像阴影检测与去除源码(高分期末大作业项目).zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。基于Python的图像阴影检

    Android阅读器源码

    Android阅读器源码是用于在Android平台上开发电子书阅读器应用的源代码。阅读器可以支持多种电子书格式,如EPUB、PDF、TXT等,并提供诸如翻页、搜索、书签、夜间模式等功能。

    该项目包含为与用户合作的微电网能源管理系统的多目标优化而开发的matlab代码.zip

    1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    人力资源数据分析看版.xlsx

    Excel数据看板,Excel办公模板,Excel模板下载,Excel数据统计,数据展示

    MS15-058 SQL Server 2008 R2 Service Pack 3 补丁包

    MS15-058 SQL Server 2008 R2 Service Pack 3 SQLServer2008R2-KB3045314-x64 不太好找,找到了,就分享一下吧

    基于LabView+MATLAB的说话人识别系统.zip

    labview 与 C 和BASIC 一样,LabVIEW [2]也是通用的编程系统,有一个完成任何编程任务的庞大函数库。LabVIEW [3]的函数库包括数据采集、GPIB、串口控制、数据分析、数据显示及数据存储,等等。LabVIEW [3]也有传统的程序调试工具,如设置断点、以动画方式显示数据及其子程序(子VI)的结果、单步执行等等,便于程序的调试。 LabVIEW [2](Laboratory Virtual Instrument Engineering Workbench)是一种用图标代替文本行创建应用程序的图形化编程语言。传统文本编程语言根据语句和指令的先后顺序决定程序执行顺序,而 LabVIEW 则采用数据流编程方式,程序框图中节点之间的数据流向决定了VI及函数的执行顺序。VI指虚拟仪器,是 LabVIEW 的程序模块。 LabVIEW [2] 提供很多外观与传统仪器(如示波器、万用表)类似的控件,可用来方便地创建用户界面。用户界面在 LabVIEW 中被称为前面板。使用图标和连线,可以通过编程对前面板上的对象进行控制。这就是图形化源代码,又称G代码。

    JavaSE技术题Java开发过程中的面试

    JavaSE技术题Java开发过程中的面试

    Python实现基于深度学习的预测区域电力负荷模型源码+项目说明(高分项目).zip

    Python实现基于深度学习的预测区域电力负荷模型源码+项目说明.zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 Python实现基于深度学习的预测区域电力负荷模型源码+项目说明.zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 Python实现基于深度学习的预测区域电力负荷模型源码+项目说明.zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 Python实现基于深度学习的预测区域电力负荷模型源码+项目说明.zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 Python实现基于深度学习的预测区域电力负荷模型源码+项目说明.zip已获导师指导并通过的97分的高分期末大作业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 Python实现基于

    会创意年会策划.docx

    年会班会资料,节目策划,游戏策划,策划案,策划方案,活动方案,筹办,公司年会,开场白,主持人,策划主题,主持词,小游戏。

    基于物联网MQTT协议的智能停车场管理系统

    基于物联网MQTT协议的智能停车场管理系统 本项目为Eclipse搭建的Maven Web项目 前端采用BootStrap框架 后端采用SSM框架 主要特点: 1.管理员与用户两大功能组 2.基于Apache Apollo服务器的MQTT通信,用于实现地锁装置与管理系统的通信 3.采用第三方微信支付BufPay

    com.baidu.netdisk_12.9.6.apk

    com.baidu.netdisk_12.9.6.apk

    合并两个有序链表是一个常见的编程问题.txt

    两个有序链表的合并pta

    ASP.NET Core 运行时 6.0.29

    ASP.NET Core 运行时 6.0.29

    计算机科学与技术专业数据结构试题 2002年7月杭州电子科技大学期末考试题.pdf

    杭州电子科技大学,期末考试资料,计算机专业期末考试试卷,试卷及答案,数据结构。

Global site tag (gtag.js) - Google Analytics