打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
在VB6/VBA中使用正则表达式
一、关于起因

最近在Office的QQ群里问如何在一串字符串中提取数值并加总的问题。如果使用正则表达式可以非常迅速的解决这个问题。

那么今天我就探讨一下在VB6/VBA中使用正则表达式的方法及代码,另外为了快速测试正则表达式,我给大家推荐notepad++及使用方式。

二、操作步骤

1、按Alt+F11进入Excel的VBE环境,依次选择“工具/引用”菜单,选择“Microsoft VBScript Regular Express”;

2、插入一个模块,在模块中输入如下所示的代码;

 1 Function SumValueInText(TargetRange As Range) As Double 2     Dim mRegExp As RegExp 3     Dim mMatches As MatchCollection      '匹配字符串集合对象 4     Dim mMatch As Match        '匹配字符串 5  6     Set mRegExp = New RegExp 7     With mRegExp 8         .Global = True                              'True表示匹配所有, False表示仅匹配第一个符合项 9         .IgnoreCase = True                          'True表示不区分大小写, False表示区分大小写10         .Pattern = "([0-9])?[.]([0-9])+|([0-9])+"   '匹配字符模式11         Set mMatches = .Execute(TargetRange.Text)   '执行正则查找,返回所有匹配结果的集合,若未找到,则为空12         For Each mMatch In mMatches13             SumValueInText = SumValueInText + CDbl(mMatch.Value)14         Next15     End With16     17     Set mRegExp = Nothing18     Set mMatches = Nothing19 End Function

3、在工作表的A列单元格中输入各种测试字符串,在B列单元格中输入自定义函数进行测试,结果如下图所示;

三、Attention

在VB6/VBA中使用正则表达式时,我们也可以省去第一步,即采用后期绑定的方式来使用正则表达式,但是代码要做相应的调整,如下所示为调整后的代码。

 1 Function SumValueInText(TargetRange As Range) As Double 2     Dim mRegExp As Object       '正则表达式对象 3     Dim mMatches As Object      '匹配字符串集合对象 4     Dim mMatch As Object        '匹配字符串 5  6     Set mRegExp = CreateObject("Vbscript.Regexp") 7     With mRegExp 8         .Global = True                              'True表示匹配所有, False表示仅匹配第一个符合项 9         .IgnoreCase = True                          'True表示不区分大小写, False表示区分大小写10         .Pattern = "([0-9])?[.]([0-9])+|([0-9])+"   '匹配字符模式11         Set mMatches = .Execute(TargetRange.Text)   '执行正则查找,返回所有匹配结果的集合,若未找到,则为空12         For Each mMatch In mMatches13             SumValueInText = SumValueInText + CDbl(mMatch.Value)14         Next15     End With16     17     Set mRegExp = Nothing18     Set mMatches = Nothing19 End Function
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
vb使用正则表达式
咕吧课堂:excel vba正则表达式就是这么玩的
vba正则表达式入门
VBA中的正则表达式(二)
学习VBA,报表做到飞 第四章 正则表达式 4.3 正则表达式的方法和属性
Word VBA|通配符查找、替换、VBA及正则表达式
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服