VBS中的正则表达式的用法大全 原创
VBS正则表达式函数 主要用在asp中效果明显 1、表单验证功能
复制代码 代码如下:
Function Validate(strng,patrn) Dim regEx Set regEx = New RegExp regEx.Pattern = patrn regEx.IgnoreCase = True regEx.Global = True Validate = regEx.test(strng) Set regEx = Nothing End Function
使用例子 If Validate(Fdr.Name,"F\d{4}_P\d{4}")=True Then ... ... End If
测试 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
2、替换功能
复制代码 代码如下:
'========================== '用正则表达式实现替换 '========================== function replaceregex(patern,str,tagstr) dim regex,matches set regex=new regExp regex.pattern=patern regex.IgnoreCase=true regex.global=true matches=regex.replace(str,tagstr) replaceregex=matches end function
3、ubb功能http://www.jb51.net/html/200608/6/574.htm
以下是 作者:LCX的内容
以前一直没有好好的学过,这次整理一下。
正则中/d+就是代表一个或多个数字,用这个做例子。
RegExp就是建立正则的对像。如Set regEx = New RegExp。regEx.Pattern 就是来设置正则的模式的,如
regEx.Pattern ="/d+"。regEx.IgnoreCase = True ' 设置是否区分大小写。regEx.Global = True ' 设置全程可用性。
RegExp对像有3种方法,分别是execute、test、replace。
test方法是对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。RegExp.Global属性对Test方法没有影响。如果找到了匹配的模式,Test方法返回True;否则返回False。
例子:
复制代码 代码如下:
Function RegExpTest(patrn, strng)Dim regEx, retVal ' 建立变量。Set regEx = New RegExp ' 建立正则表达式。regEx.Pattern = patrn ' 设置模式。regEx.IgnoreCase = False ' 设置是否区分大小写。retVal = regEx.Test(strng) ' 执行搜索测试。If retVal Then RegExpTest = "找到一个或多个匹配。"Else RegExpTest = "未找到匹配。"End IfEnd FunctionMsgBox(RegExpTest("\d+", "abcd1234"))MsgBox(RegExpTest("\d+", "abcd"))
Replace 方法替换在正则表达式查找中找到的文本,例子:
复制代码 代码如下:
Function ReplaceTest(patrn, replStr)Dim regEx, str1 ' 建立变量。str1 = "dog 123."Set regEx = New RegExp ' 建立正则表达式。regEx.Pattern = patrn ' 设置模式。regEx.IgnoreCase = True ' 设置是否区分大小写。ReplaceTest = regEx.Replace(str1, replStr) ' 作替换。End Function
MsgBox(ReplaceTest("\d+", "cat")) ‘将字符串中的123替换为cat
Execute 方法,则是对指定的字符串执行正则表达式搜索。这里又涉及到Match对像和Matches 集合。Matches 集合就是match的对像集合。Matches 集合中包含若干独立的 Match 对象,只能使用 RegExp 对象的 Execute 方法来创建之。例子:
复制代码 代码如下:
Function RegExpTest(patrn, strng) Dim regEx, Match, Matches ' 建立变量。 Set regEx = New RegExp ' 建立正则表达式。 regEx.Pattern = patrn ' 设置模式。 regEx.IgnoreCase = True ' 设置是否区分大小写。 regEx.Global = True ' 设置全程可用性。 Set Matches = regEx.Execute(strng) ' 执行搜索。 For Each Match in Matches ' 遍历 Matches 集合。 RetStr = RetStr & Match.FirstIndex & "。匹配的长度为"&" "RetStr = RetStr & Match.Length &" " RetStr = RetStr & Matches(0) &" " '值为123 RetStr = RetStr & Matches(1)&" " '值为44 RetStr = RetStr & Match.value&" " '值为123和44的数组 RetStr = RetStr & vbCRLF Next RegExpTest = RetStrEnd FunctionMsgBox(RegExpTest("\d+", "123a44"))