经典JavaScript正则表达式实战 菜鸟(http://www.cainiao8.com/ ) 邮箱:runningtortoise@hotmail.com 目录 正则表达式实战... 1 匹配结尾的数字... 2 统一空格个数... 3 判断字符串是不是由数字组成... 3 电话号码正则... 3 手机号码正则表达式... 4 使用正则表达式实现删除字符串中的空格:... 4 限制文本框只能输入数字和小数点等等... 5 替换小数点前内容为指定内容... 5 只匹配中文的正则表达式... 5 返回字符串的中文字符个数... 6 正则表达式取得匹配IP地址前三段... 6 匹配
- 与
-
界面设计测试规范 -
《古典写实美女》漫画教程 -
安远――消失的光年 -
asp.net 2.0多语言网站解决方案 要求匹配item里的title而不匹配channel里的title。 基本正则: / - $0$< / li>
- $1$< / li>
- $2$< / li>
- $3$< / li>
- A< / li>
- B< / li>
- C< / li>
- D< / li>
- 之间的内容... 7 用正则表达式获得文件名... 7 绝对路径变相对路径... 8 用户名正则... 8 匹配英文地址... 8 正则匹配价格... 9 身份证号码的匹配... 10 要求文本有指定行数... 10 单词首字母大写... 10 正则验证日期格式... 11 去掉文件的后缀名... 12 验证邮箱的正则表达式... 12 匹配源代码中的链接... 13 匹配链接的文字... 14 正则判断标签是否闭合... 14 用正则获得指定标签的内容... 15 正则判断是否为数字与字母的混合... 16 空格与英文同时存在... 17 显示或者保存正则表达式匹配的部分内容... 18 正则表达式替换变量... 18 正则替换指定属性中的文本... 19 将阿拉伯数字替换为中文大写形式... 20 替换文本中的URL为链接... 21 从HTML代码段删除指定标签极其内容... 21 用正则给文本分段... 22 转换源代码中的标签... 22 给属性添加双引号... 23 给table加上tbody. 25 去掉标签的所有属性... 25 正则替换特定单词... 25 指定文字高亮显示... 26 删除标签... 27 错误贴... 28 太难贴... 28 匹配数字的“正则”. 28 正则资源... 28 匹配结尾的数字 来源:如何用 JAVASCRIPT 正则表达式 取出字符串最后一组数字,谢谢 如 30CAC0040 取出40 3SFASDF92 取出92 正则如下:/\d+$/g 统一空格个数 来源:正则匹配空格的问题 字符串内字符键有空格,但是空格的数量可能不一致,通过正则将空格的个数统一变为一个。 例如:蓝 色 理 想 变成:蓝 色 理 想 aobert的正则: 判断字符串是不是由数字组成 来源:有没有简单的方法判断字符串由数字组成? 这个正则比较简单,写了一个测试 电话号码正则 来源:想问一下关于电话号码的正则判断 :求一个验证电话号码的JS正则 /^\d{3,4}-\d{7,8}(-\d{3,4})?$/ 区号必填为3-4位的数字,区号之后用“-”与电话号码连接 ^\d{3,4}- 电话号码为7-8位的数字 \d{7,8} 分机号码为3-4位的数字,非必填,但若填写则以“-”与电话号码相连接 (-\d{3,4})? 手机号码正则表达式 正则验证手机号,忽略前面的0,支持130-139,150-159。忽略前面0之后判断它是11位的。 cloeft的正则: /^0*(13|15)\d{9}$/ ^0*匹配掉开头任意数量的0。 由于手机号码是13任意数字9位,和15任意数字9位,所以可以用(13|15)\d{9}匹配。 测试代码如下: function testReg(reg,str){ return reg.test(str); } var reg = /^0*(13|15)\d{9}$/; var str = '13889294444'; var str2 = '12889293333'; var str3 = '23445567'; document.write(testReg(reg,str)+'
'); document.write(testReg(reg,str2)+'
'); document.write(testReg(reg,str3)+'
'); 使用正则表达式实现删除字符串中的空格: 来源:请问JS中有没有去掉空格的函数 代码以及测试代码如下: 测试的结果如下: length:11 ltrim length:10 rtrim length:10 trim length:9 限制文本框只能输入数字和小数点等等 来源:文本框输入限制的问题???? 只能输入数字和小数点 var reg = /^\d*\.?\d{0,2}$/ 开头有若干个数字,中间有0个或者一个小数点,结尾有0到2个数字。 只能输入小写的英文字母和小数点,和冒号,正反斜杠(:./\) var reg = /[a-z\.\/\\:]+/; a-z包括了小写的英文字母,\.是小数点,\/和\\分别是左右反斜线,最后是冒号。整个组成一个字符 集和代码任一均可,最后在加上+,1或者多个。 替换小数点前内容为指定内容 来源:求一正则表达式! 请问 怎么把这个字符串的小数点前面的字符替换为我自定义的字符串啊? 例如:infomarket.php?id=197 替换为 test.php?id=197 应该可以把第一个点“.”之前的所有单词字符替换为test就可以了。我写的正则如下: 原帖的有点复杂,没太看明白。 只匹配中文的正则表达式 来源:关于上传的时候,只能选择中文名称的图片(是否可以用TOASCII方法呢?) 前两天看的《JavaScript开发王》里恰好有中文的unicode范围,正则如下: /[\u4E00-\u9FA5\uf900-\ufa2d]/ 写了一个简单的测试,会把所有的中文替换成“哦”。 返回字符串的中文字符个数 来源:有没返回中文字符字节的函数! 一般的字符长度对中文和英文都是不分别的 如JS里的length,那么如何返回字符串中中文字符的个数 呢?guoshuang老师在原帖中给出了解决方案,我又没看懂…… 不过我自己也想到了一个办法:先去掉非中文字符,再返回length属性。函数以及测试代码如下: 结果: 5 2 中文两个,数字三个,正确。 下面的测试也正确。 var str = "中文123tets@#!#%$#[][{}"; document.write(str.length+'
'); document.write(cLength(str)); 正则表达式取得匹配IP地址前三段 来源:如何用正则取IP前3段 192.168.118.101,192.168.118.72, 192.168.118.1都替换成:192.168.118 只要匹配掉最后一段并且替换为空字符串就行了,正则如下: /\.\d{1,3}$/ 匹配结尾的.n,.nn或者.nnn。 测试代码如下: function replaceReg(reg,str){ return str.replace(reg,'') } var reg = /\.\d{1,3}$/; var str = '192.168.118.101'; var str2 = '192.168.118.72'; var str3 = '192.168.118.1'; document.write(replaceReg(reg,str)+'
'); document.write(replaceReg(reg,str2)+'
'); document.write(replaceReg(reg,str3)+'
'); 相似的有,这个帖子里有一个验证IP地址的方法:求检验MAC地址的正则表达例子 匹配
- 与
- 之间的内容 来源:请教个正则的小问题吧
- safsf
- safsf
- safsf
- 起到下个
- 之间的内容。 正则如下: /
- [\s\S]+?
- /i 首先匹配两侧的ul标签,中间的[\s\S]+?可以匹配一个或者多个任意字符,一定要非贪婪,否则会匹 配
- safsf
- safsf
- 。 用正则表达式获得文件名 来源:C:\006.JPG c:\images\tupian\006.jpg 可能是直接在盘符根目录下,也可能在好几层目录下,要求替换到只剩文件名。 xlez的正则如下: /[^\\\/]*[\\\/]+/g 首先匹配非左右斜线字符0或多个,然后是左右斜线一个或者多个。形如“xxx/”或者“xxx\”或者“/”或 者“\” 函数以及测试代码: 注意,\需要转义。 绝对路径变相对路径 来源:讨论一个正则 将


xxx
。 (\s*\/>) 匹配img类的结束,即/>。 (\s*?>[\s\S]*?<\/\1>) 匹配\p类标签的结束标签。>是其实标签末尾,之后是标签内容若干个任意字符,最后的<\/\1>就是 结束标签了。 加上一个或就可以解决了,最后的完整正则表达式: 整个正则:/<([a-z]+)(\s*\w*?\s*=\s*".+?")*(\s*?>[\s\S]*?<\/\1>|\s*\/>)/i 拿这个正则,只要匹配到了就表示闭合,没匹配到则没有闭合。不过没有考虑相同标签嵌套的问题,例 如aaaaaa 蓝色理想 [\s\S]*?<\/title>/gi 首先是title标签,内容为任意字符若干个,然后是title结束标签。这个正则已经能匹配到所有的title标 签。 首先,我简单地修改了一下原正则: /[^<>]*?<\/title>/gi, 因为title里面不应该再嵌有其它标签,这个正则同样是匹配所有标题的内容,最后再加上不去匹 配channel中的title。整个正则如下: /[^<>]*?<\/title>(?!\s*<\/channel>)/gi (?!\s*<\/channel>)表示要匹配字符串的后面不能跟着若干个空格和一个channel的结束标签。 原帖里有很方便的测试工具,这里就不给测试代码了。 正则判断是否为数字与字母的混合 来源:关于正则 不能小于12位,且必须为字母和数字的混合。 验证字符串包含数字简单,验证字符串包含字母也简单,验证字符串不包含其它字符也简单,可以用这 三个正则分别检查一次字符串,逻辑运算出最终结果。 但是怎么能把这些功能写进一个正则表达式里呢?这个问题真有点伤脑筋。 下面是lexrus的正则: /^([a-z]+(?=[0-9])|[0-9]+(?=[a-z]))[a-z0-9]+$/ig 思路非常的清晰啊: [a-z]+(?=[0-9]) 字母开头,后面必须紧跟着数字。 [0-9]+(?=[a-z] 数字开头,后面必须紧跟着字母。 [a-z0-9]+ 后面的字符只要是数字或者字母就可以了。经过测试,发现不好使,123dd会被识别为不合 法,dd123则为合法,可见“数字开头,紧跟字母”的正则没有起作用。测试代码如下: 结果为: false,true,false,false 结果中的第三个,将'123dd'判断为非法是错误的。刚开始以为是g的问题,去掉了还是不好使。应该 是浏览器bug,我认为lexrus的正则是正确的,可能是浏览器无法处理或”|”的两边都包含正向预 查(?=)。 修改之后的正则如下: /^(([a-z]+[0-9]+)|([0-9]+[a-z]+))[a-z0-9]*$/i 意思和上面差不多,但是没有使用正向预查,测试代码如下: 结果为 false,true,true,false 正确。 空格与英文同时存在 来源:正则问题请指教啊! 匹配英文以及空格,要求必须既有英文字母又有空格。 这个思路和上面的差不多,只要把数字改成空格就可以了。正则如下: /^(([a-z]+\s+)|(\s+[a-z]+))[a-z\s]*$/i 英文开头加空格,或者是空格开头加英文,后面可以是英文或者空格。测试代码如下: 利用这个思路也可以实现英文空格英文,英文单词多于两个的匹配。同样,也可以把英文字母换成单词 字符\w。 显示或者保存正则表达式匹配的部分内容 有如下电话号码: 13588888333 13658447322 13558885354 13587774654 13854554786 要求,要求只匹配135开头的电话,但是匹配结果只保留135后面的数字。 由于JavaScript里的正则不支持(?=xx)xxx的模式,只支持xxx(?=xx)的模式。所以只能将135后面 的内容作为一个子正则表达式匹配的内容,然后再在后面引用。 Carl给出的函数如下: function f(phoneNumber) { var pattern = /^(135)(\d{8})$/; if(pattern.test(phoneNumber)) return phoneNumber.replace(pattern,"$2"); else return "不是135打头的手机号码!"; } /^(135)(\d{8})$/ 正则中,135作为开头表示第一个子正则表达式,第二个括号内的子正则表达式则匹配后面的8个数 字,然后在replace中使用$2就可以引用这个子正则表达式匹配的内容了。测试代码如下: 正则表达式替换变量 来源:求教正则 有一个数组: var _A = ['A','B','C','D']; 有一个有“变量”的字符串。 var _B = '
O'Malley's West 要求将所有onclick属性中的’替换成\’,也就是将单引号转义。 首先,需要匹配onclick属性: /onclick\s*=\s*".+?"/ig 然后再将所有的’都替换成\’就可以了。整个测试的代码如下:
将阿拉伯数字替换为中文大写形式 来源:正则问题 将123替换成壹贰叁。 只要匹配一个数字就可以了,测试代码如下(如果显示为乱码就调整一下浏览器的字符编码): function replaceReg(reg,str){ return str.replace(reg,function(m){return arr[m];}) } arr=new Array("零","壹","贰","叁","肆","伍","陆","柒","捌","玖"); var reg = /\d/g; var str = '13889294444'; var str2 = '12889293333'; var str3 = '23445567'; document.write(replaceReg(reg,str)+'
'); document.write(replaceReg(reg,str2)+'
'); document.write(replaceReg(reg,str3)+'
'); 替换文本中的URL为链接 来源:求一链接替换正则 将一个用户输入的一段文字中的url替换成可以点击的link地址。例如:http://www.blueidea.com可 以替换成 [url]http://www.cctv.com[/url] 或http://www. blueidea.com. 这个正则的关键就在于匹配链接,匹配之后,在两边加上a标签和属性不是问题。 /http:\/\/[\w-]*(\.[\w-]*)+/ig 首先匹配http://。 [\w-]*是可能的www和bbs等。 \.[\w-]*匹配.xxx形式,至少有一个。 测试代码如下: 从HTML代码段删除指定标签极其内容 来源:关于正则的问题 在一段代码中去除 哎。就剩下我了。 但是,如果使用类似的正则: /<(script|head|%)[\s\S]*?\/(script|head|%)>/ig 匹配有嵌套的标签: 哎。就剩下我了。 实际匹配的内容是: 这是因为[\s\S]*?里的非贪婪造成的。可以使用JavaScript正则里的反向引用来解决这个问题,如果 起始标签匹配了head,那么结束标签也必须是head。最后的正则如下: /<(script|head|%)[\s\S]*?\/\1>/ig 用正则给文本分段 来源:怎样用正则分段落 源代码:[title]标题一[/title]内容一232323sdfga [title]标题二[/title]内容二2232323 [title]标题 三[/title]内容三2232323 要把文本分段成如下格式: 一、[title]标题一[/title]内容一232323sdfga 二、[title]标题二[/title]内容二2232323 三、[title]标题三[/title]内容三2232323 只要用正则匹配title就可以了,所以正则比较简单 /\[title\]/ig 至于开始的的汉字序号,只要一个数组就解决了,最终代码如下: 转换源代码中的标签 来源:一个正则上的问题 将代码中的HTML标签img转换为[img]url[/img]。 /
/ig 这段正则和匹配链接标签的正则基本一样,修改如下,标签名img,没有结束标签而是>结束。 测试代码如下: 第二个是替换object代码嵌入的flash代码替换为[swf]url[/swf]。 针对原文的正则如下: /
test
也被判断为合格,可以通过把最后的匹配p类结束标签写成子正则表达式,并且更改为非贪心,然后在 匹配结果中检查是否成对。正则如下: /<([a-z]+)(\s*\w*?\s*=\s*".+?")*(\s*?>[\s\S]*?(<\/\1>)+|\s*\/>)/i 用正则获得指定标签的内容 来源:求一正则 有如下代码: 
O'Malley's West
将阿拉伯数字替换为中文大写形式 来源:正则问题 将123替换成壹贰叁。 只要匹配一个数字就可以了,测试代码如下(如果显示为乱码就调整一下浏览器的字符编码): function replaceReg(reg,str){ return str.replace(reg,function(m){return arr[m];}) } arr=new Array("零","壹","贰","叁","肆","伍","陆","柒","捌","玖"); var reg = /\d/g; var str = '13889294444'; var str2 = '12889293333'; var str3 = '23445567'; document.write(replaceReg(reg,str)+'
'); document.write(replaceReg(reg,str2)+'
'); document.write(replaceReg(reg,str3)+'
'); 替换文本中的URL为链接 来源:求一链接替换正则 将一个用户输入的一段文字中的url替换成可以点击的link地址。例如:http://www.blueidea.com可 以替换成 [url]http://www.cctv.com[/url] 或http://www. blueidea.com. 这个正则的关键就在于匹配链接,匹配之后,在两边加上a标签和属性不是问题。 /http:\/\/[\w-]*(\.[\w-]*)+/ig 首先匹配http://。 [\w-]*是可能的www和bbs等。 \.[\w-]*匹配.xxx形式,至少有一个。 测试代码如下: 从HTML代码段删除指定标签极其内容 来源:关于正则的问题 在一段代码中去除 哎。就剩下我了。 但是,如果使用类似的正则: /<(script|head|%)[\s\S]*?\/(script|head|%)>/ig 匹配有嵌套的标签: 哎。就剩下我了。 实际匹配的内容是: 这是因为[\s\S]*?里的非贪婪造成的。可以使用JavaScript正则里的反向引用来解决这个问题,如果 起始标签匹配了head,那么结束标签也必须是head。最后的正则如下: /<(script|head|%)[\s\S]*?\/\1>/ig 用正则给文本分段 来源:怎样用正则分段落 源代码:[title]标题一[/title]内容一232323sdfga [title]标题二[/title]内容二2232323 [title]标题 三[/title]内容三2232323 要把文本分段成如下格式: 一、[title]标题一[/title]内容一232323sdfga 二、[title]标题二[/title]内容二2232323 三、[title]标题三[/title]内容三2232323 只要用正则匹配title就可以了,所以正则比较简单 /\[title\]/ig 至于开始的的汉字序号,只要一个数组就解决了,最终代码如下: 转换源代码中的标签 来源:一个正则上的问题 将代码中的HTML标签img转换为[img]url[/img]。 /