news 2026/4/15 16:57:20

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【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技能

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 16:54:26

构建高效协作的软件测试团队:策略与实践

在当今快速迭代的软件开发环境中,测试团队不再是简单的“bug发现者”,而是保障产品质量、推动技术创新的关键力量。随着敏捷开发、DevOps和持续集成/持续部署(CI/CD)的普及,测试工作面临着更高的效率要求和更复杂的协作…

作者头像 李华
网站建设 2026/4/15 13:43:29

为什么你的Rust PHP扩展总是崩溃?深入调试核心函数的3大方法

第一章:为什么你的Rust PHP扩展总是崩溃?在尝试将 Rust 与 PHP 集成以提升性能时,许多开发者遭遇运行时崩溃、段错误或不可预测的行为。根本原因往往并非语言本身的问题,而是对 PHP 扩展生命周期和内存管理模型的误解。不正确的内…

作者头像 李华
网站建设 2026/4/7 3:07:56

农业试验数据处理指南(R语言方差分析核心技术大公开)

第一章:农业产量的 R 语言方差分析概述在农业科学研究中,评估不同处理条件(如施肥方案、作物品种或灌溉方式)对产量的影响是核心任务之一。方差分析(ANOVA)作为一种统计方法,能够有效判断多个组…

作者头像 李华
网站建设 2026/4/10 3:33:18

抗锯齿技术如何影响帧率?:基于GPU性能数据的7项实测结论

第一章:抗锯齿技术如何影响帧率?抗锯齿技术(Anti-Aliasing, AA)被广泛用于图形渲染中,以消除边缘的“锯齿”现象,提升视觉质量。然而,这种画质提升通常伴随着性能开销,尤其是对帧率&…

作者头像 李华
网站建设 2026/4/12 0:52:19

上海医日健集团拿下“专精特新”!数智药柜惠及万千家庭

近日,上海医日健数智健康医药集团成功斩获上海市“专精特新”企业认证的消息,在大健康产业圈引发广泛关注。作为衡量中小企业核心竞争力的关键标尺,“专精特新”认证的落地,不仅是对医日健深耕数智健康领域实力的权威背书&#xf…

作者头像 李华
网站建设 2026/4/14 22:40:45

藏在峰丛间的水墨诗画,羊皮洞的瀑与石之歌

在贵州连绵的喀斯特峰丛之间,藏着无数被岁月雕琢的自然奇观,羊皮洞便是其中一处养在深闺的秘境。它没有知名景区的喧嚣人潮,唯有流水与山石相依的静谧,当你循着林间湿润的气息走近,便会被那从崖壁间奔涌而出的瀑布&…

作者头像 李华