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中使用正则表达式的主要知识点和实用技巧,可作为日常开发参考。

相关推荐
冬天vs不冷30 分钟前
EasyExcel导出自动回显中文,读取自动转换码值(基于全局转换器与自定义注解)
java·excel
光军oi34 分钟前
Mysql从入门到精通day5————子查询精讲
android·数据库·mysql
qr9j422332 小时前
Django自带的Admin后台中如何获取当前登录用户
数据库·django·sqlite
cherry52303 小时前
【PostgreSQL】【第4章】PostgreSQL的事务
数据库·postgresql
IT成长日记6 小时前
【MySQL基础】聚合函数从基础使用到高级分组过滤
数据库·mysql·聚合函数
Guarding and trust8 小时前
python系统之综合案例:用python打造智能诗词生成助手
服务器·数据库·python
夜间出没的AGUI8 小时前
SQLiteBrowser 的详细说明,内容结构清晰,涵盖核心功能、使用场景及实用技巧
数据库
不再幻想,脚踏实地9 小时前
MySQL(一)
java·数据库·mysql
gc_229910 小时前
C#测试Excel开源组件ExcelDataReader
c#·excel·exceldatareader