- vba正则表达式的说明
 
| 项目 | 说明 | 
|---|---|
| Pattern | 在这里写正则表达式,例:[\d]{2,4} | 
| IgnoreCase | 大小写区分,默认false:区分;true:不区分 | 
| Global | true:全体检索;false:最小匹配 | 
| Test | 类似perl正则前的m,匹配项目 | 
| Replace | 类似perl正则前的s,替换项目 | 
| Execute | 类似java的matcher,然后能取出里边的group1,group2,group3;或者perl里匹配的各个括号的值 | 
※正则表达式怎么写,这里不做说明,我是做perl的时候看了那本骆驼书然后顿悟的,以前特别怕写正则,现在还挺喜欢写的,特别是用正则解决了问题后
2.Test的用法
Sub test()
    Dim RE  As String
    Dim patt As String
    Set RE = CreateObject("VBScript.RegExp")
    pattern = "[0-9]{2,4}"
    With RE
        .pattern = patt
        .IgnoreCase = True
        .Global = True
        If .test("word1234aa") Then
            Debug.Print "11111"
        Else
            Debug.Print "22222"
        End If
        If .test("word4aa") Then
            Debug.Print "33333"
        Else
            Debug.Print "44444"
        End If
    End With
    Set RE = Nothing
End Sub
 
执行结果:
 
 原因:没有引正则的包
 
 很遗憾,macos vba无法使用正则,因为没有正则的引用
 
 但是上边我写的正则匹配应该是没问题的
3.Replace的用法
Sub test()
    Dim RE As String
    Set RE = CreateObject("VBScript.RegExp")
    With RE
        .pattern = "[0-9]{2,4}"
        .IgnoreCase = False
        .Global = True
    End With
    Dim str As String, ret As String
    str = "I love you 123"
    ret = RE.Replace(str, "zy")
    Debug.Print ret
    Set RE = Nothing
    '输出结果:I love you zy
End Sub
 
4.Execute的用法
Sub test()
    Dim RE, patt As String, pmatch
    Set RE = CreateObject("VBScript.RegExp")
    patt = "I love ([\d]+) and ([\d]+)"
    With RE
        .pattern = patt
        .IgnoreCase = True
        .Global = True
         Set pmatch = .Execute("I love 123 and 456")
         If pmatch.Count > 0 Then
            Debug.Print pmatch(0) & "======" & pmatch(1)
         End If
    End With
    Set pmatch = Nothing
    Set RE = Nothing
End Sub
                




![[代码学习]einsum详解](https://img-blog.csdnimg.cn/2b2d39c35924425fb7f8f557d1a15f80.png#pic_center)













