匹配中文字符的正则表达式:
[u4e00-u9fa5]
匹配双字节字符(包括汉字在内):
[^x00-xff]
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;}
匹配空行的正则表达式:
[s| ]*
匹配HTML标记的正则表达式:
/<(.*)>.*</1>|<(.*) />/
匹配首尾空格的正则表达式:
(^s*)|(s*$)
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
String.prototype.trim = function(){
return this.replace(/(^s*)|(s*$)/g, "");
}
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!")
}
}
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))
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")
var s2=s.replace(re,"")
alert(s1+s2) //结果为:abcefgi
var s1=s.replace(/(.).*1/g,"$1")
var re=new RegExp("["+s1+"]","g")
var s2=s.replace(re,"")
alert(s1+s2) //结果为:abcefgi
我原来在CSDN上发贴寻求一个表达式来实现去除重复字符的方法,最终没有找到,这是我能想到的最简单的实现方法。思路是使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连。这个方法对于字符顺序有要求的字符串可能不适用。
得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1
s="http://www.9499.net/page1.htm"
s=s.replace(/(.*/){0,}([^.]+).*/ig,"$2")
alert(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,''))"
相关推荐
这个“vb正则表达式实例”很可能是为了帮助开发者测试和理解正则表达式的工作原理而设计的一个应用程序。下面将详细探讨正则表达式的基本概念、在VB.NET中的应用以及如何使用它们进行文本匹配。 1. 正则表达式基础 ...
正则表达式(Regular Expression,简称regex)是用于匹配字符串的一种模式,广泛应用于文本处理...在文档"常用的正则表达式(实例).doc"中,可能会包含更多具体的实例和使用场景,帮助你加深理解和运用这些正则表达式。
正则表达式语法和实例总结 正则表达式是一种强大的字符串匹配工具,广泛...正则表达式是一种强大的字符串匹配工具,通过学习和掌握正则表达式的语法和实例,可以更好地处理字符串匹配问题,提高开发效率和代码质量。
这本书详细介绍了各种正则表达式的模式和用法,提供了丰富的实例,帮助读者掌握这一技术。 在正则表达式中,基本的元素包括: 1. 字符匹配: - `\d` 表示任何数字,相当于 `[0-9]`。 - `\w` 匹配字母、数字或...
正则表达式(Regular Expression),则是一种强大的文本处理工具,用于匹配、查找、替换和提取特定模式的字符串。在VB中结合使用正则表达式,可以增强对输入数据的验证和处理能力,确保程序的数据有效性。 本实例...
这个合集提供的HTML和Java正则表达式实例,为开发者提供了一个快速参考的工具,帮助他们在开发过程中快速有效地实现数据验证功能。理解并熟练运用这些正则表达式,对于提高代码质量和用户体验都有极大的帮助。在实际...
在“神奇的匹配 正则表达式求精之旅”中,你将通过实例解析,逐步掌握这些概念,并学会如何在不同的编程环境中应用它们。无论是在文本编辑器中查找和替换,还是在脚本语言中处理复杂的数据过滤,正则表达式都将是你...
正则表达式(Regular Expression,简称regex)是用于匹配字符串的一种模式,广泛应用于文本处理、数据验证、搜索和替换等场景。在Java编程语言中,正则表达式提供了强大的字符串处理功能,使得开发者能够高效地处理...
通过上述介绍,我们可以看出 Oracle 支持的正则表达式功能非常强大,不仅能够满足基本的字符串匹配需求,还能处理更加复杂的数据清洗和转换任务。熟练掌握这些函数将极大地提高我们在处理数据时的效率和准确性。
#### 三、常用正则表达式实例 下面列举了一些常用的正则表达式示例及其应用场景: - **匹配中文字符**:`[\u4e00-\u9fa5]`。可用于识别和处理包含中文的文本。 - **匹配双字节字符(包括汉字在内)**:`[^\x00-\xff...
Java正则表达式是Java编程语言中用于处理字符串的强大工具,它允许程序员通过模式匹配来查找、替换或分割文本。...阅读《JAVA正则表达式实例教程.pdf》将帮助你更全面地理解和掌握Java正则表达式。
正则表达式是一种强大的文本匹配工具,被广泛应用于各种编程语言中,用于实现字符串搜索、替换等操作。本篇文章将根据给定的内容介绍一系列常见的正则表达式及其应用场景,帮助初学者快速掌握正则表达式的使用方法。...