VBS中的正则表达式的用法大全

2025-05-29 0 44

VBS正则表达式函数
主要用在asp中效果明显
1、表单验证功能

复制代码 代码如下:

FunctionValidate(strng,patrn)
DimregEx
SetregEx=NewRegExp
regEx.Pattern=patrn
regEx.IgnoreCase=True
regEx.Global=True
Validate=regEx.test(strng)
SetregEx=Nothing
EndFunction

使用例子

IfValidate(Fdr.Name,"F\\d{4}_P\\d{4}")=TrueThen
……
EndIf


2、替换功能

复制代码 代码如下:


'==========================
'用正则表达式实现替换
'==========================
functionreplaceregex(patern,str,tagstr)
dimregex,matches
setregex=newregExp
regex.pattern=patern
regex.IgnoreCase=true
regex.global=true
matches=regex.replace(str,tagstr)
replaceregex=matches
endfunction


3、ubb功能

以下是 作者: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 If
End Function
MsgBox(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 = RetStr
End Function
MsgBox(RegExpTest("\\d+", "123a44"))

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 VBS中的正则表达式的用法大全 https://www.kuaiidc.com/88803.html

相关文章

发表评论
暂无评论