vbs字符串正则_VBS中的正则表达式的用法大全

这篇文章主要为大家介绍下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功能

以下是 作者: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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值