2025年VBA之正则表达式(14)-- 提取指定位数的数字

VBA之正则表达式(14)-- 提取指定位数的数字实例需求 只提取字符串中 2 位 4 位的数字 无小数点 提取结果为蓝色数字 测试字符串 6688 部门员工共 10 人与 2019 年 6 月成功完成销售额订单数 689 这次的话题有些太简单了吧 任何学习正则的同学基本上首先学会的就是这个知识点 一起回顾一下

大家好,我是讯享网,很高兴认识大家。

实例需求:只提取字符串中2位~4位的数字(无小数点),提取结果为蓝色数字。
测试字符串:6688-部门员工共10人与2019年6月成功完成销售额订单数689

这次的话题有些太简单了吧!?任何学习正则的同学基本上首先学会的就是这个知识点,一起回顾一下。

匹配数字有两种表示方法:

  • [0-9]
  • \d

2位~4位指的是数字字符的重复次数,可以用\d\d|\d\d\d|\d\d\d\d,重复次数比较少,组合也不多,这样还可以,其实应该用大括号\d{2,4},注意不是{2-4}

正则表达式已经有了,如果我说这次讲解到结束,接下来是掌声还是鸡蛋呢 … …

用代码测试一下效果吧。

Sub GetDigits() Dim strTxt As String Dim objRE As Object Dim objMH As Object strTxt = "6688-部门员工共10人与2019年6月成功完成销售额订单数689" Set objRE = CreateObject("vbscript.regexp") objRE.Global = True objRE.Pattern = "(\d{2,4})" For Each objMH In objRE.Execute(strTxt) Debug.Print objMH.submatches(0) Next End Sub 

讯享网

结果如下:

6688
10
2019
8899
66
689

输出结果中为什么有889966怎么被五马分尸了,正则不靠谱呀!
其实这个6位数字被分为两次匹配成功,\d{4}匹配8899\d{2}匹配66
在这里插入图片描述
讯享网
看来需要修改正则表达式,既然提取指定位数的数字,那么潜台词就是说提取的数字组之前和之后都不是数字,幸好记得 \D可以匹配非数字,修改一句代码如下。

讯享网objRE.Pattern = "\D+(\d{2,4})\D+" 

再次测试代码,结果如下:

10

为嘛结果只有一个数字了,6688689怎么不见了。 \D可以匹配非数字是正确的,但是不能用于匹配字符串的开始位置和结尾位置,所以头和尾的数字不符合匹配模式,只能再修改匹配模式了。

最终的示例代码如下。

Sub GetDigits() Dim strTxt As String Dim objRE As Object Dim objMH As Object strTxt = "6688-部门员工共10人与2019年6月成功完成销售额订单数689" Set objRE = CreateObject("vbscript.regexp") objRE.Global = True objRE.Pattern = "(?:^|\D)(\d{2,4})(?=\D|$)" For Each objMH In objRE.Execute(strTxt) Debug.Print objMH.submatches(0) Next End Sub 

结果如下:

6688
10
2019
689

终于得到了正确结果,貌似一个简单的小问题,实际上用到的知识点还真不少。


相关博文链接:
VBA之正则表达式(12)-- 格式调整
VBA之正则表达式(13)-- 字符串变换
VBA之正则表达式(14)-- 提取指定位数的数字
VBA之正则表达式(15)-- 提取数字求和
VBA之正则表达式(16)-- 提取非重复值
VBA之正则表达式(17)-- 提取多组数据(去除末尾字符)

小讯
上一篇 2025-01-10 19:02
下一篇 2025-01-11 19:32

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/23960.html