VBA 中正则表达式使用指南

1. 正则表达式基础用法

1.1 引入正则表达式

  • 前期绑定 :工具 → 引用 → Microsoft VBScript Regular Expressions 5.5

    vba 复制代码
    Dim regex As New RegExp
  • 后期绑定

    vba 复制代码
    Set regex = CreateObject("VBScript.RegExp")

1.2 常用属性设置

vba 复制代码
regex.Global = True  ' 全局搜索(默认False,只匹配第一个)
regex.Pattern = "表达式内容"  ' 设置正则表达式
regex.IgnoreCase = True  ' 忽略大小写(默认False)

1.3 基本操作方法

vba 复制代码
Set k = regex.Execute(目标字符串)  ' 执行匹配,返回MatchCollection对象
n = regex.Replace(目标字符串, 替换字符串)  ' 替换操作

1.4 With语句简化

vba 复制代码
With regex
    .Global = True
    .Pattern = "正则表达式"
    .Replace "", ""
    .Execute 目标字符串
End With

2. 正则表达式元字符

元字符 说明
\d 匹配数字
. 匹配除换行符外的任意字符
? 匹配前导字符0次或1次
+ 匹配前导字符1次或多次
* 匹配前导字符0次或多次
{n,m} 匹配前导字符n到m次
() 分组捕获
[] 字符集合
` `

3. 高级技巧

3.1 分组与引用

vba 复制代码
.Pattern = "(\d{4})-(\d{2})-(\d{2})"  ' 分组匹配日期
' 使用$1,$2,$3引用分组

3.2 非捕获分组

vba 复制代码
.Pattern = "(?:\d{4})"  ' 使用?:表示非捕获分组

3.3 Test方法

vba 复制代码
If regex.Test(目标字符串) Then
    ' 匹配成功执行的代码
End If

3.4 SubMatches用法(捕获分组值)

vba 复制代码
Sub 捕获分组值()
    Set regx = CreateObject("VBScript.RegExp")
    With regx
        .Global = True
        .Pattern = "(\w{3,}) (\d+)"
        Set mat = .Execute([A1])
        For Each m In mat
            n = n + 1
            Cells(n + 1, 3) = .Replace(m.Value, "$1")  ' 第一分组
            Cells(n + 1, 4) = .Replace(m.Value, "$2")  ' 第二分组
        Next
    End With
End Sub

4. 常用正则表达式示例

  1. 整数匹配

    • 正整数:^[0-9]*[1-9][0-9]*$
    • 整数:^-?\d+$
  2. 浮点数匹配

    • 正浮点数:^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
  3. 邮箱匹配

    • ^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
  4. URL匹配

    • ^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$
  5. 中文匹配

    • [\u4e00-\u9fa5]
  6. 电话号码

    • ^(\d{3,4}-)?\d{7,8}$
  7. IP地址

    • ^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$
  8. 日期匹配

    • ^\d{4}-\d{1,2}-\d{1,2}$

5. 实用示例代码

5.1 首尾锚定示例

vba 复制代码
Sub test()
    Set regx = CreateObject("VBScript.RegExp")
    With regx
        .Global = True
        .Pattern = "^[A-Z]+\d+$"
        For Each Rng In [A1:A17]
            Set mat = .Execute(Rng)
            For Each m In mat
                n = n + 1
                Cells(n, 2) = m
            Next
        Next
    End With
End Sub

5.2 循环正则表达式

vba 复制代码
' 将正则表达式放到数组中循环
Dim patterns(2)
patterns(0) = "\d+"
patterns(1) = "[A-Z]+"
patterns(2) = "[\u4e00-\u9fa5]+"

For Each p In patterns
    regex.Pattern = p
    ' 执行匹配操作
Next

以上内容总结了VBA中使用正则表达式的主要知识点和实用技巧,可作为日常开发参考。

相关推荐
新法国菜4 分钟前
MySql知识梳理之DDL语句
数据库·mysql
DarkAthena1 小时前
【GaussDB】全密态等值查询功能测试及全密态技术介绍
数据库·gaussdb
ShawnLeiLei1 小时前
2.3 Flink的核心概念解析
数据库·python·flink
石皮幼鸟2 小时前
数据完整性在所有场景下都很重要吗?
数据库·后端
大只鹅3 小时前
Centos7.9 Docker26容器化部署 MySql9.4 一主一从的同步复制部署
mysql·centos
叁沐3 小时前
MySQL 28 读写分离有哪些坑?
mysql
nightunderblackcat4 小时前
新手向:异步编程入门asyncio最佳实践
前端·数据库·python
DarkAthena4 小时前
【GaussDB】使用MySQL客户端连接到GaussDB的M-Compatibility数据库
数据库·mysql·gaussdb
livemetee4 小时前
Flink2.0学习笔记:使用HikariCP 自定义sink实现数据库连接池化
大数据·数据库·笔记·学习·flink
XXD啊4 小时前
Redis 从入门到实践:Python操作指南与核心概念解析
数据库·redis·python