当前位置 博文首页 > VBS中的正则表达式的用法大全 原创

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

    作者:admin 时间:2021-09-11 19:05

    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://blog.iis7.com/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 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"))

    jsjbwy
下一篇:没有了