经典正则表达式
匹配中文字符的正则表达式: [/u4e00-/u9fa5]
匹配双字节字符(包括汉字在内):[^/x00-/xff]
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){returnthis.replace([^/x00-/xff]/g,"aa".length;}
匹配空行的正则表达式:/n[/s|]*/r
匹配HTML标记的正则表达式:/<(.*)>.*<///1>|<(.*)//>/
匹配首尾空格的正则表达式:(^/s*)|(/s*$)
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
String.prototype.trim=function()
{
returnthis.replace(/(^/s*)|(/s*$)/g,"";
}
利用正则表达式分解和转换IP地址:
下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:
functionIP2V(ip)
{
re=/(/d+)/.(/d+)/.(/d+)/.(/d+)/g//匹配IP地址的正则表达式
if(re.test(ip))
{
returnRegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
thrownewError("NotavalidIPaddress!"
}
}
不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:
varip="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-./?%&=]*)?
利用正则表达式去除字串中重复的字符的算法程序:[注:此程序不正确,原因见本贴回复]
vars="abacabefgeeii"
vars1=s.replace(/(.).*/1/g,"$1"
varre=newRegExp("["+s1+"]","g"
vars2=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)
利用正则表达式限制网页表单里的文本框输入内容:
用正则表达式限制只能输入中文: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,''))"
postedon2004年06月24日11:32PM
Feedback
#回复:经典正则表达式2004-08-032:03PM阿赖.com
正则表达式,相关链接
http://blog.csdn.net/laily/category/19548.aspx
http://blog.csdn.net/laily/archive/2004/06/30/30525.aspx微软的正则表达式教程(五):选择/编组和后向引用
http://blog.csdn.net/laily/archive/2004/06/30/30522.aspx微软的正则表达式教程(四):限定符和定位符
http://blog.csdn.net/laily/archive/2004/06/30/30517.aspx微软的正则表达式教程(三):字符匹配
http://blog.csdn.net/laily/archive/2004/06/30/30514.aspx微软的正则表达式教程(二):正则表达式语法和优先权顺序
http://blog.csdn.net/laily/archive/2004/06/30/30511.aspx微软的正则表达式教程(一):正则表达式简介
http://blog.csdn.net/laily/archive/2004/06/30/30360.aspx小程序大作为:高级查找/替换、正则表达式练习器、Javascript脚本程序调试器
http://blog.csdn.net/laily/archive/2004/06/24/25872.aspx经典正则表达式
正则表达式,正规表达式,正则表达式匹配,正则表达式语法,模式匹配,正规表达式匹配javascript正则表达式ASP正则表达式ASP.NET正则表达式C#正则表达式JSP正则表达式PHP正则表达式VB.NET正则表达式VBSCript正则表达式编程delphi正则表达式jscript
#回复:经典正则表达式2004-08-032:12PM阿赖
正则表达式regularexpression
正则表达式RegExp
模式pattern
匹配Match
.NET命名空间:System.Text.RegularExpression
#回复:经典正则表达式2004-08-032:14PM阿赖
补充:
^/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-]+)*@[/w-]+(/.[/w-]+)+$ //匹配email地址
^[a-zA-z]+://匹配(/w+(-/w+)*)(/.(/w+(-/w+)*))*(/?/S*)?$ //匹配url
#回复:经典正则表达式2004-09-087:37PMtotoro
利用正则表达式去除字串中重复的字符的算法程序:
vars="abacabefgeeii"
vars1=s.replace(/(.).*/1/g,"$1"
varre=newRegExp("["+s1+"]","g"
vars2=s.replace(re,""
alert(s1+s2)//结果为:abcefgi
===============================
如果vars="abacabefggeeii"
结果就不对了,结果为:abeicfgg
正则表达式的能力有限
#回复:经典正则表达式2004-09-102:07PM阿赖
RE:totoro
谢谢你的指点,这个javascript正则表达式程序算法确实有问题,我会试着找更好的办法!!!
#回复:经典正则表达式2004-10-113:52PMLai
1.确认有效电子邮件格式
下面的代码示例使用静态Regex.IsMatch方法验证一个字符串是否为有效电子邮件格式。如果字符串包含一个有效的电子邮件地址,则IsValidEmail方法返回true,否则返回false,但不采取其他任何操作。您可以使用IsValidEmail,在应用程序将地址存储在数据库中或显示在ASP.NET页中之前,筛选出包含无效字符的电子邮件地址。
[VisualBasic]
FunctionIsValidEmail(strInAsString)AsBoolean
'ReturntrueifstrInisinvalide-mailformat.
ReturnRegex.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})(/]?)quot
EndFunction
[C#]
boolIsValidEmail(stringstrIn)
{
//ReturntrueifstrInisinvalide-mailformat.
returnRegex.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})(/]?)quot;
}
2.清理输入字符串
下面的代码示例使用静态Regex.Replace方法从字符串中抽出无效字符。您可以使用这里定义的CleanInput方法,清除掉在接受用户输入的窗体的文本字段中输入的可能有害的字符。CleanInput在清除掉除@、-(连字符)和.(句点)以外的所有非字母数字字符后返回一个字符串。
[VisualBasic]
FunctionCleanInput(strInAsString)AsString
'Replaceinvalidcharacterswithemptystrings.
ReturnRegex.Replace(strIn,"[^/w/.@-]",""
EndFunction
[C#]
StringCleanInput(stringstrIn)
{
//Replaceinvalidcharacterswithemptystrings.
returnRegex.Replace(strIn,@"[^/w/.@-]","";
}
3.更改日期格式
以下代码示例使用Regex.Replace方法来用dd-mm-yy的日期形式代替mm/dd/yy的日期形式。
[VisualBasic]
FunctionMDYToDMY(inputAsString)AsString
ReturnRegex.Replace(input,_
"/b(?<month>/d{1,2})/(?<day>/d{1,2})/(?<year>/d{2,4})/b",_
"${day}-${month}-${year}"
EndFunction
[C#]
StringMDYToDMY(Stringinput)
{
returnRegex.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://www.contoso.com:8080/letters/readme.html”将返回“http:8080”。
[VisualBasic]
FunctionExtension(urlAsString)AsString
DimrAsNewRegex("^(?<proto>/w+)://[^/]+?(?<port>:/d+)?/",_
RegexOptions.Compiled)
Returnr.Match(url).Result("${proto}${port}"
EndFunction
[C#]
StringExtension(Stringurl)
{
Regexr=newRegex(@"^(?<proto>/w+)://[^/]+?(?<port>:/d+)?/",
RegexOptions.Compiled);
returnr.Match(url).Result("${proto}${port}";
}