当前位置: 首页 > news >正文

【Excel VBA 编程】第59讲:VBA正则的隐形助手——非捕获组(?:)

上一期讲到了捕获组,它尽职尽责地找到我们关心的文本模式,并将其分门别类地记录到 SubMatches 集合中。然而,当匹配逻辑变得复杂时,这位“助手”过于细致的记录有时反而会成为一种负担

什么是非捕获组

为了卸下负担,解决“只需分组、无需捕获”的需求,非捕获组应运而生

VBA正则表达式中的非捕获组是一个非常实用的分组工具,可以帮助我们优化表达式结构并提升匹配效率,其语法为:

(?:Expression)

其中 Expression 是要进行分组的正则表达式,通过预定义字符、字符类、量词等组合而成

当我们需要使用圆括号 () 来对表达式进行分组,但又不希望这个分组被单独捕获出来作为结果的一部分时,可考虑使用非捕获组。这可以避免产生不必要的子匹配项,使结果更清晰

非捕获组 VS 捕获组

为了直观理解非捕获组和捕获组的区别,我们来看两段代码

以下示例代码需求:从文本中提取日期信息,并分别输出完整的日期以及年、月、日三个部分,这里需要用到捕获组

Dim match' 创建正则表达式对象With CreateObject("VBScript.RegExp").Global = True ' 搜索全部匹配项.IgnoreCase = False ' 区分大小写.Pattern = "(\d{4})-(\d{2})-(\d{2})"For Each match In .Execute("合同签订时间:2025-09-17,生效日:2025-10-15")Debug.Print matchDebug.Print match.SubMatches(0)Debug.Print match.SubMatches(1)Debug.Print match.SubMatches(2)NextEnd With

代码的核心是要搜索的模式:\d{4} 匹配4位数字(年),\d{2} 匹配2位数字(月或日),因此执行后结果:

从图中可以看出,SubMatches中已经分别提取到了年、月和日这三个部分

然而有些场景我们可能只关心月和日两个分组数据,此时SubMatches就不需要存储年份相关的分组内容,因此代码修改为:

Dim match' 创建正则表达式对象With CreateObject("VBScript.RegExp").Global = True ' 搜索全部匹配项.IgnoreCase = False ' 区分大小写.Pattern = "(?:\d{4})-(\d{2})-(\d{2})"For Each match In .Execute("合同签订时间:2025-09-17,生效日:2025-10-15")Debug.Print matchDebug.Print match.SubMatches(0)Debug.Print match.SubMatches(1)NextEnd With

匹配模式中(?:\d{4})即为非捕获组,就是在捕获组基础上增加问号和冒号这两个符号,它的作用是匹配但不捕获年份,因此实际只有两个捕获组:

  • match.SubMatches(0)存放月,如"09"

  • match.SubMatches(1)存放日,如"17"

这样处理之后,SubMatches结果中保留的均为目标数据,有效排除了非必要分组信息的干扰

总之,将不需要引用的分组改为非捕获组是一个良好的编程习惯,使代码逻辑变得清晰,避免分组编号混乱。另外,在非常复杂的正则表达式中,将不需要引用的普通捕获组 () 改为非捕获组 (?:),还能带来性能提升

结束语

今天的分享就到这里了,咱们下期继续

公众号同时也在不间断地分享免费的编程案例,如果想学习更多的编程知识,无论是用来提升自动化办公效率还是想提升自我,都可以关注我的公众号“努力鸭是黑色的”,解锁更多的VBA技能

http://www.cnnetsun.cn/news/68924.html

相关文章:

  • RN Hooks 设计规范与反模式清单
  • 《Advanced Science》最新研究:多自由度折纸模块构建可编程机械超材料网络
  • 用梯形图+SCL玩转FactoryIO码垛控制
  • 7、Nagios 安装与功能拓展全解析
  • 读懂 NVIDIA Jetson OP-TEE 官方源码:从目录结构到 JetPack / Yocto 构建与运行的完整指南
  • LobeChat能否实现邀请码注册机制?控制用户增长节奏
  • Angular AOT编译失败?这份官方文档解读帮你10分钟定位问题
  • PHP环境下医疗数据备份怎么做?5种高可用方案对比分析
  • 【Python库选型避坑手册】:5年踩坑经验总结出的7条黄金法则
  • PHP 8.6 JIT编译器重大升级(指令优化黑科技曝光)
  • Keil串口通信全教程:UART初始化、数据收发(中断/查询模式)+串口调试助手验证
  • 揭秘WebSocket频繁断线之谜:3种常见错误码分析与修复方案
  • LPDDR6 JEDEC 原文解读学习—2.4 Data Packet Format(3)(~持续更新)
  • 【PHP性能优化关键一步】:深入PHP 8.6内存泄漏监控与自动预警方案
  • PHP 8.6兼容性测试实战(资深架构师亲授迁移经验)
  • 从入门到精通:用R Shiny打造可交互的多维度数据仪表盘
  • 光伏阵列遇到局部阴影就像吃火锅被隔壁桌抢肉——憋屈得很。今天咱们用Python整活,搞个3×3电池板的阴影仿真模型,重点观察串联结构在阴影下的输出曲线怎么抽风
  • 你还不知道HTTP/3的这5个性能秘密?:资深架构师20年经验倾囊相授
  • 如何将EF Core响应时间降低80%?一线大厂都在用的4种策略
  • BGP综合实验
  • 大数据采集与处理技术实训室
  • 基于MATLAB 火灾检测系统,可以实现图片的火苗检测。 推荐matlab2019A及以后。
  • Harmony学习之本地数据存储
  • 【PHP扩展性能优化秘籍】:基于Rust的函数调试与内存泄漏排查指南
  • Flutter 状态管理终极指南(一):从 setState 到 Riverpod 2.0
  • Symfony 8路由缓存机制揭秘:如何让应用加载快如闪电
  • 基于STM32智能营养称系统的设计与实现_352
  • PHP 8.6升级必看:5个关键兼容性检测步骤,避免生产环境崩溃
  • 医疗行业PHP数据备份最佳实践(20年专家亲授方案)
  • 4、Gateway