老铁们,大家好,相信还有很多朋友对于javascript 正则表达式和js正则表达式子表达式的相关问题不太懂,没关系,今天就由我来为大家分享分享javascript 正则表达式以及js正则表达式子表达式的问题,文章篇幅可能偏长,希望可以帮助到大家,下面一起来看看吧!
在JavaScript的世界里,正则表达式(Regular Expression)是一个强大且无处不在的工具。它能帮助我们轻松处理文本,进行搜索、替换、提取信息等操作。作为一名前端开发者,熟练掌握正则表达式,无疑会大大提高我们的工作效率。本文将从入门到精通,带你领略JavaScript正则表达式的魅力。
一、正则表达式的入门
1.1 什么是正则表达式?
正则表达式是一种用于描述字符组合的模式。它可以帮助我们快速、高效地处理文本。在JavaScript中,正则表达式通常用于字符串匹配、替换、分割等操作。
1.2 正则表达式的语法
正则表达式的语法相对复杂,下面是一些常见的符号及其含义:
| 符号 | 含义 |
|---|---|
| [] | 匹配方括号内的任意一个字符 |
| “”d | 匹配任意一个数字字符(0-9) |
| “”w | 匹配任意一个字母、数字或下划线字符 |
| . | 匹配除换行符以外的任意一个字符 |
| * | 匹配前面的子表达式零次或多次 |
| + | 匹配前面的子表达式一次或多次 |
| ? | 匹配前面的子表达式零次或一次 |
| ^ | 匹配输入字符串的开始位置 |
| $ | 匹配输入字符串的结束位置 |
| () | 标记子表达式的开始和结束位置,子表达式可以获取供以后使用 |
1.3 一个简单的例子
以下是一个简单的正则表达式例子,用于匹配包含“abc”的字符串:
“`javascript
var regex = /abc/;
“`
这个正则表达式匹配包含“abc”的字符串,例如:
“`javascript
var str = “
javascript中的正则表达式有什么规范
正则表达式规则
1.正则表达式规则
1.1普通字符
字母、数字、汉字、下划线、以及后边章节中没有特殊定义的标点符号,都是”普通字符”。表达式中的普通字符,在匹配一个字符串的时候,匹配与之相同的一个字符。
举例1:表达式”c”,在匹配字符串”abcde”时,匹配结果是:成功;匹配到的内容是:”c”;匹配到的位置是:开始于2,结束于3。(注:下标从0开始还是从1开始,因当前编程语言的不同而可能不同)
举例2:表达式”bcd”,在匹配字符串”abcde”时,匹配结果是:成功;匹配到的内容是:”bcd”;匹配到的位置是:开始于1,结束于4。
——————————————————————————–
1.2简单的转义字符
一些不便书写的字符,采用在前面加”\”的方法。这些字符其实我们都已经熟知了。
表达式
可匹配
\r,\n
代表回车和换行符
\t
制表符
\\
代表”\”本身
还有其他一些在后边章节中有特殊用处的标点符号,在前面加”\”后,就代表该符号本身。比如:^,$都有特殊意义,如果要想匹配字符串中”^”和”$”字符,则表达式就需要写成”\^”和”\$”。
表达式
可匹配
\^
匹配 ^符号本身
\$
匹配$符号本身
\.
匹配小数点(.)本身
这些转义字符的匹配方法与”普通字符”是类似的。也是匹配与之相同的一个字符。
举例1:表达式”\$d”,在匹配字符串”abc$de”时,匹配结果是:成功;匹配到的内容是:”$d”;匹配到的位置是:开始于3,结束于5。
——————————————————————————–
1.3能够与'多种字符'匹配的表达式
正则表达式中的一些表示方法,可以匹配'多种字符'其中的任意一个字符。比如,表达式”\d”可以匹配任意一个数字。虽然可以匹配其中任意字符,但是只能是一个,不是多个。这就好比玩扑克牌时候,大小王可以代替任意一张牌,但是只能代替一张牌。
表达式
可匹配
\d
任意一个数字,0~9中的任意一个
\w
任意一个字母或数字或下划线,也就是 A~Z,a~z,0~9,_中任意一个
\s
包括空格、制表符、换页符等空白字符的其中任意一个
.
小数点可以匹配除了换行符(\n)以外的任意一个字符
举例1:表达式”\d\d”,在匹配”abc123″时,匹配的结果是:成功;匹配到的内容是:”12″;匹配到的位置是:开始于3,结束于5。
举例2:表达式”a.\d”,在匹配”aaa100″时,匹配的结果是:成功;匹配到的内容是:”aa1″;匹配到的位置是:开始于1,结束于4。
——————————————————————————–
1.4自定义能够匹配'多种字符'的表达式
使用方括号 [ ]包含一系列字符,能够匹配其中任意一个字符。用 [^ ]包含一系列字符,则能够匹配其中字符之外的任意一个字符。同样的道理,虽然可以匹配其中任意一个,但是只能是一个,不是多个。
表达式
可匹配
[ab5@]
匹配”a”或”b”或”5″或”@”
[^abc]
匹配”a”,”b”,”c”之外的任意一个字符
[f-k]
匹配”f”~”k”之间的任意一个字母
[^A-F0-3]
匹配”A”~”F”,”0″~”3″之外的任意一个字符
举例1:表达式”[bcd][bcd]”匹配”abc123″时,匹配的结果是:成功;匹配到的内容是:”bc”;匹配到的位置是:开始于1,结束于3。
举例2:表达式”[^abc]”匹配”abc123″时,匹配的结果是:成功;匹配到的内容是:”1″;匹配到的位置是:开始于3,结束于4。
——————————————————————————–
1.5修饰匹配次数的特殊符号
前面章节中讲到的表达式,无论是只能匹配一种字符的表达式,还是可以匹配多种字符其中任意一个的表达式,都只能匹配一次。如果使用表达式再加上修饰匹配次数的特殊符号,那么不用重复书写表达式就可以重复匹配。
使用方法是:”次数修饰”放在”被修饰的表达式”后边。比如:”[bcd][bcd]”可以写成”[bcd]{2}”。
表达式
作用
{n}
表达式重复n次,比如:”\w{2}”相当于”\w\w”;”a{5}”相当于”aaaaa”
{m,n}
表达式至少重复m次,最多重复n次,比如:”ba{1,3}”可以匹配”ba”或”baa”或”baaa”
{m,}
表达式至少重复m次,比如:”\w\d{2,}”可以匹配”a12″,”_456″,”M12344″…
?
匹配表达式0次或者1次,相当于{0,1},比如:”a[cd]?”可以匹配”a”,”ac”,”ad”
+
表达式至少出现1次,相当于{1,},比如:”a+b”可以匹配”ab”,”aab”,”aaab”…
*
表达式不出现或出现任意次,相当于{0,},比如:”\^*b”可以匹配”b”,”^^^b”…
举例1:表达式”\d+\.?\d*”在匹配”It costs$12.5″时,匹配的结果是:成功;匹配到的内容是:”12.5″;匹配到的位置是:开始于10,结束于14。
举例2:表达式”go{2,8}gle”在匹配”Ads by goooooogle”时,匹配的结果是:成功;匹配到的内容是:”goooooogle”;匹配到的位置是:开始于7,结束于17。
——————————————————————————–
1.6其他一些代表抽象意义的特殊符号
一些符号在表达式中代表抽象的特殊意义:
表达式
作用
^
与字符串开始的地方匹配,不匹配任何字符
$
与字符串结束的地方匹配,不匹配任何字符
\b
匹配一个单词边界,也就是单词和空格之间的位置,不匹配任何字符
进一步的文字说明仍然比较抽象,因此,举例帮助大家理解。
举例1:表达式”^aaa”在匹配”xxx aaa xxx”时,匹配结果是:失败。因为”^”要求与字符串开始的地方匹配,因此,只有当”aaa”位于字符串的开头的时候,”^aaa”才能匹配,比如:”aaa xxx xxx”。
举例2:表达式”aaa$”在匹配”xxx aaa xxx”时,匹配结果是:失败。因为”$”要求与字符串结束的地方匹配,因此,只有当”aaa”位于字符串的结尾的时候,”aaa$”才能匹配,比如:”xxx xxx aaa”。
举例3:表达式”.\b.”在匹配”@@@abc”时,匹配结果是:成功;匹配到的内容是:”@a”;匹配到的位置是:开始于2,结束于4。
进一步说明:”\b”与”^”和”$”类似,本身不匹配任何字符,但是它要求它在匹配结果中所处位置的左右两边,其中一边是”\w”范围,另一边是非”\w”的范围。
举例4:表达式”\bend\b”在匹配”weekend,endfor,end”时,匹配结果是:成功;匹配到的内容是:”end”;匹配到的位置是:开始于15,结束于18。
一些符号可以影响表达式内部的子表达式之间的关系:
表达式
作用
|
左右两边表达式之间”或”关系,匹配左边或者右边
()
(1).在被修饰匹配次数的时候,括号中的表达式可以作为整体被修饰
(2).取匹配结果的时候,括号中的表达式匹配到的内容可以被单独得到
举例5:表达式”Tom|Jack”在匹配字符串”I'm Tom, he is Jack”时,匹配结果是:成功;匹配到的内容是:”Tom”;匹配到的位置是:开始于4,结束于7。匹配下一个时,匹配结果是:成功;匹配到的内容是:”Jack”;匹配到的位置时:开始于15,结束于19。
举例6:表达式”(go\s*)+”在匹配”Let's go go go!”时,匹配结果是:成功;匹配到内容是:”go go go”;匹配到的位置是:开始于6,结束于14。
举例7:表达式”¥(\d+\.?\d*)”在匹配”$10.9,¥20.5″时,匹配的结果是:成功;匹配到的内容是:”¥20.5″;匹配到的位置是:开始于6,结束于10。单独获取括号范围匹配到的内容是:”20.5″。
——————————————————————————–
2.正则表达式中的一些高级规则
2.1匹配次数中的贪婪与非贪婪
在使用修饰匹配次数的特殊符号时,有几种表示方法可以使同一个表达式能够匹配不同的次数,比如:”{m,n}”,”{m,}”,”?”,”*”,”+”,具体匹配的次数随被匹配的字符串而定。这种重复匹配不定次数的表达式在匹配过程中,总是尽可能多的匹配。比如,针对文本”dxxxdxxxd”,举例如下:
表达式
匹配结果
(d)(\w+)
“\w+”将匹配第一个”d”之后的所有字符”xxxdxxxd”
(d)(\w+)(d)
“\w+”将匹配第一个”d”和最后一个”d”之间的所有字符”xxxdxxx”。虽然”\w+”也能够匹配上最后一个”d”,但是为了使整个表达式匹配成功,”\w+”可以”让出”它本来能够匹配的最后一个”d”
由此可见,”\w+”在匹配的时候,总是尽可能多的匹配符合它规则的字符。虽然第二个举例中,它没有匹配最后一个”d”,但那也是为了让整个表达式能够匹配成功。同理,带”*”和”{m,n}”的表达式都是尽可能地多匹配,带”?”的表达式在可匹配可不匹配的时候,也是尽可能的”要匹配”。这种匹配原则就叫作”贪婪”模式。
非贪婪模式:
在修饰匹配次数的特殊符号后再加上一个”?”号,则可以使匹配次数不定的表达式尽可能少的匹配,使可匹配可不匹配的表达式,尽可能的”不匹配”。这种匹配原则叫作”非贪婪”模式,也叫作”勉强”模式。如果少匹配就会导致整个表达式匹配失败的时候,与贪婪模式类似,非贪婪模式会最小限度的再匹配一些,以使整个表达式匹配成功。举例如下,针对文本”dxxxdxxxd”举例:
表达式
匹配结果
(d)(\w+?)
“\w+?”将尽可能少的匹配第一个”d”之后的字符,结果是:”\w+?”只匹配了一个”x”
(d)(\w+?)(d)
为了让整个表达式匹配成功,”\w+?”不得不匹配”xxx”才可以让后边的”d”匹配,从而使整个表达式匹配成功。因此,结果是:”\w+?”匹配”xxx”
更多的情况,举例如下:
举例1:表达式”<td>(.*)</td>”与字符串”<td><p>aa</p></td><td><p>bb</p></td>”匹配时,匹配的结果是:成功;匹配到的内容是”<td><p>aa</p></td><td><p>bb</p></td>”整个字符串,表达式中的”</td>”将与字符串中最后一个”</td>”匹配。
举例2:相比之下,表达式”<td>(.*?)</td>”匹配举例1中同样的字符串时,将只得到”<td><p>aa</p></td>”,再次匹配下一个时,可以得到第二个”<td><p>bb</p></td>”。
——————————————————————————–
2.2反向引用\1,\2…
表达式在匹配时,表达式引擎会将小括号”()”包含的表达式所匹配到的字符串记录下来。在获取匹配结果的时候,小括号包含的表达式所匹配到的字符串可以单独获取。这一点,在前面的举例中,已经多次展示了。在实际应用场合中,当用某种边界来查找,而所要获取的内容又不包含边界时,必须使用小括号来指定所要的范围。比如前面的”<td>(.*?)</td>”。
其实,”小括号包含的表达式所匹配到的字符串”不仅是在匹配结束后才可以使用,在匹配过程中也可以使用。表达式后边的部分,可以引用前面”括号内的子匹配已经匹配到的字符串”。引用方法是”\”加上一个数字。”\1″引用第1对括号内匹配到的字符串,”\2″引用第2对括号内匹配到的字符串……以此类推,如果一对括号内包含另一对括号,则外层的括号先排序号。换句话说,哪一对的左括号”(“在前,那这一对就先排序号。
举例如下:
举例1:表达式”('|”)(.*?)(\1)”在匹配”'Hello',”World””时,匹配结果是:成功;匹配到的内容是:”'Hello'”。再次匹配下一个时,可以匹配到””World””。
举例2:表达式”(\w)\1{4,}”在匹配”aa bbbb abcdefg ccccc 111121111 999999999″时,匹配结果是:成功;匹配到的内容是”ccccc”。再次匹配下一个时,将得到 999999999。这个表达式要求”\w”范围的字符至少重复5次,注意与”\w{5,}”之间的区别。
举例3:表达式”<(\w+)\s*(\w+(=('|”).*?\4)?\s*)*>.*?</\1>”在匹配”<td id='td1' style=”bgcolor:white”></td>”时,匹配结果是成功。如果”<td>”与”</td>”不配对,则会匹配失败;如果改成其他配对,也可以匹配成功。
正则表达式规则如下:
表达式描述表达式描述
^匹配行首$匹配行尾
.匹配任何单个字符 []匹配集合中的字符
[^]匹配不在集合中的字符?匹配前一个样式0或1次
*匹配前一个样式0或更多次+匹配前一个样式1或更多次
|匹配前一个或后一个样式&匹配前一个样式0或更多次
#匹配前一个样式1或更多次{} Group char to form one pattern
() Group and remember\下一个字符直接用原意(只对a-z之外的字符有效)
<匹配词的开始>匹配词的结尾
\x##匹配ASCII码为##(16进制)的字符\N###匹配ASCII码为##(10进制)的字符
\o###匹配ASCII码为##(8进制)的字符\a匹配\a
\b匹配\b\f匹配\f
\r匹配 0x13(回车)\t匹配 0x09(跳格)
\v匹配\v\e匹配 Esc(0x05)
\n匹配0x10(换行)\s匹配空格(回车,换行,制表符,空格)
\S匹配非空格(!\s)\w整字匹配
\W非整字匹配\d匹配数字
\D匹配非数字\U匹配大写字母
\L匹配小写字母\C后面开始大小写敏感
\c后面开始大小写不敏感\#匹配前面定义的组(#: 1-9, a-f)
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工具可以查看到捕获结果,
在线工具网址:
求一段javascript正则表达式,100分
以前搜集了很久全给你了
匹配中文字符的正则表达式: [\u4e00-\u9fa5]
匹配双字节字符(包括汉字在内):[^\x00-\xff]
匹配空行的正则表达式:\n[\s| ]*\r
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*)\/>/
匹配首尾空格的正则表达式:(^\s*)|(\s*$)
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?
(1)应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,”aa”).length;}
(2)应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现
String.prototype.trim= function()
{
return this.replace(/(^\s*)|(\s*$)/g,””);
}
(3)应用:利用正则表达式分解和转换IP地址
function IP2V(ip)//IP地址转换成对应数值
{
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g//匹配IP地址的正则表达式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error(“Not a valid IP address!”)
}
}
(4)应用:从URL地址中提取文件名的javascript程序
s=””;
s=s.replace(/(.*\/){0,}([^\.]+).*/ig,”$2″);//Page1.htm
(5)应用:利用正则表达式限制网页表单里的文本框输入内容
用正则表达式限制只能输入中文:onkeyup=”value=value.replace(/[^\u4E00-\u9FA5]/g,'')” onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))”
用正则表达式限制只能输入全角字符: onkeyup=”value=value.replace(/[^\uFF00-\uFFFF]/g,'')” onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))”
用正则表达式限制只能输入数字:onkeyup=”value=value.replace(/[^\d]/g,'')”onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))”
用正则表达式限制只能输入数字和英文:onkeyup=”value=value.replace(/[\W]/g,'')”onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))”
====================================================
正则表达式大全
正则表达式用于字符串处理,表单验证等场合,实用高效,但用到时总是不太把握,以致往往要上网查一番。我将一些常用的表达式收藏在这里,作备忘之用。本贴随时会更新。
匹配中文字符的正则表达式: [\u4e00-\u9fa5]
匹配双字节字符(包括汉字在内):[^\x00-\xff]
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,”aa”).length;}
匹配空行的正则表达式:\n[\s| ]*\r
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*)\/>/
匹配首尾空格的正则表达式:(^\s*)|(\s*$)
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
String.prototype.trim= function()
{
return this.replace(/(^\s*)|(\s*$)/g,””);
}
利用正则表达式分解和转换IP地址:
下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的javascript程序:
function IP2V(ip)
{
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g//匹配IP地址的正则表达式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error(“Not a valid IP address!”)
}
}
不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:
var ip=”10.100.20.168″
ip=ip.split(“.”)
alert(“IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?
利用正则表达式去除字串中重复的字符的算法程序:[注:此程序不正确,原因见本贴回复]
var s=”abacabefgeeii”
var s1=s.replace(/(.).*\1/g,”$1″)
var re=new RegExp(“[“+s1+”]”,”g”?琼?涡獢p?????浜睹扥潜桴牥掼极慢?瑨m?)
var s2=s.replace(re,””)
alert(s1+s2)//结果为:abcefgi
我原来在CSDN上发贴寻求一个表达式来实现去除重复字符的方法,最终没有找到,这是我能想到的最简单的实现方法。思路是使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连。这个方法对于字符顺序有要求的字符串可能不适用。
得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1
s=””
s=s.replace(/(.*\/){0,}([^\.]+).*/ig,”$2″)
alert(s)
利用正则表达式限制网页表单里的文本框输入内容:
用正则表达式限制只能输入中文:onkeyup=”value=value.replace(/[^\u4E00-\u9FA5]/g,'')” onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))”
用正则表达式限制只能输入全角字符: onkeyup=”value=value.replace(/[^\uFF00-\uFFFF]/g,'')” onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))”
用正则表达式限制只能输入数字:onkeyup=”value=value.replace(/[^\d]/g,'')”onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))”
用正则表达式限制只能输入数字和英文:onkeyup=”value=value.replace(/[\W]/g,'')”onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))”
补充:
^\d+$//匹配非负整数(正整数+ 0)
^[0-9]*[1-9][0-9]*$//匹配正整数
^((-\d+)|(0+))$//匹配非正整数(负整数+ 0)
^-[0-9]*[1-9][0-9]*$//匹配负整数
^-?\d+$//匹配整数
^\d+(\.\d+)?$//匹配非负浮点数(正浮点数+ 0)
^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$//匹配正浮点数
^((-\d+(\.\d+)?)|(0+(\.0+)?))$//匹配非正浮点数(负浮点数+ 0)
^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$//匹配负浮点数
^(-?\d+)(\.\d+)?$//匹配浮点数
^[A-Za-z]+$//匹配由26个英文字母组成的字符串
^[A-Z]+$//匹配由26个英文字母的大写组成的字符串
^[a-z]+$//匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$//匹配由数字和26个英文字母组成的字符串
^\w+$//匹配由数字、26个英文字母或者下划线组成的字符串
^[\w-]+(\.[\w?琼?涡獢p?????浜睹扥潜桴牥掼极慢?瑨m?-]+)*@[\w-]+(\.[\w-]+)+$//匹配email地址
^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$//匹配url
利用正则表达式去除字串中重复的字符的算法程序:
var s=”abacabefgeeii”
var s1=s.replace(/(.).*\1/g,”$1″)
var re=new RegExp(“[“+s1+”]”,”g”)
var s2=s.replace(re,””)
alert(s1+s2)//结果为:abcefgi
===============================
如果var s=”abacabefggeeii”
结果就不对了,结果为:abeicfgg
正则表达式的能力有限
RE: totoro
谢谢你的指点,这个javascript正则表达式程序算法确实有问题,我会试着找更好的办法!!!
1.确认有效电子邮件格式
下面的代码示例使用静态 Regex.IsMatch方法验证一个字符串是否为有效电子邮件格式。如果字符串包含一个有效的电子邮件地址,则 IsValidEmail方法返回 true,否则返回 false,但不采取其他任何操作。您可以使用 IsValidEmail,在应用程序将地址存储在数据库中或显示在 ASP.NET页中之前,筛选出包含无效字符的电子邮件地址。
[Visual Basic]
Function IsValidEmail(strIn As String) As Boolean
' Return true if strIn is in valid e-mail format.
Return Regex.IsMatch(strIn,(“^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$”)
End Function
[C#]
bool IsValidEmail(string strIn)
{
// Return true if strIn is in valid e-mail format.
return Regex.IsMatch(strIn,@”^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$”);
}
2.清理输入字符串
下面的代码示例使用静态 Regex.Replace方法从字符串中抽出无效字符。您可以使用这里定义的 CleanInput方法,清除掉在接受用户输入的窗体的文本字段中输入的可能有害的字符。CleanInput在清除掉除@、-(连字符)和.(句点)以外的所有非字母数字字符后返回一个字符串。
[Visual Basic]
Function CleanInput(strIn As String) As String
' Replace invalid characters with empty strings.
Return Regex.Replace(strIn,”[^\w\.@-]”,””)
End Function
[C#]
String CleanInput(string strIn)
?琼?涡獢p?????浜睹扥潜桴牥掼极慢?瑨m?{
// Replace invalid characters with empty strings.
return Regex.Replace(strIn,@”[^\w\.@-]”,””);
}
3.更改日期格式
以下代码示例使用 Regex.Replace方法来用 dd-mm-yy的日期形式代替 mm/dd/yy的日期形式。
[Visual Basic]
Function MDYToDMY(input As String) As String
Return Regex.Replace(input, _
“\b(?<month>\d{1,2})/(?<day>\d{1,2})/(?<year>\d{2,4})\b”, _
“${day}-${month}-${year}”)
End Function
[C#]
String MDYToDMY(String input)
{
return Regex.Replace(input,
“\\b(?<month>\\d{1,2})/(?<day>\\d{1,2})/(?<year>\\d{2,4})\\b”,
“${day}-${month}-${year}”);
}
Regex替换模式
本示例说明如何在 Regex.Replace的替换模式中使用命名的反向引用。其中,替换表达式${day}插入由(?<day>…)组捕获的子字符串。
有几种静态函数使您可以在使用正则表达式操作时无需创建显式正则表达式对象,而 Regex.Replace函数正是其中之一。如果您不想保留编译的正则表达式,这将给您带来方便
4.提取 URL信息
以下代码示例使用 Match.Result来从 URL提取协议和端口号。例如,“”将返回“http:8080”。
[Visual Basic]
Function Extension(url As String) As String
Dim r As New Regex(“^(?<proto>\w+)://[^/]+?(?<port>:\d+)?/”, _
RegexOptions.Compiled)
Return r.Match(url).Result(“${proto}${port}”)
End Function
[C#]
String Extension(String url)
{
Regex r= new Regex(@”^(?<proto>\w+)://[^/]+?(?<port>:\d+)?/”,
RegexOptions.Compiled);
return r.Match(url).Result(“${proto}${port}”);
}
今天有网友问:如何用正则表达式表示要么是数字要么是字母是字母的话只能是一个字母数字则无所谓?
我的回答是:
^[a-zA-Z]$|^\d+$
OK,本文到此结束,希望对大家有所帮助。




