首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VBA正则表达式和组

VBA正则表达式和组
EN

Stack Overflow用户
提问于 2017-06-07 07:06:20
回答 1查看 8.7K关注 0票数 5

对以下电子邮件正文应用以下正则表达式:

代码语言:javascript
复制
(pls[a-zA-Z0-9 .*-]*) \(([A-Z 0-9]*)\)

电子邮件正文:

代码语言:javascript
复制
pls18244a.lam64*fra-pth (PI000581) 
pls18856a.10ge*fra-pth (PI0005AW) 
pls25040a.10ge*fra-pth (IIE0004WK) 
pls27477a.10ge*fra-pth (WL050814) 
pls22099a.stm4*par-pth (PI0005TE)

返回5个匹配,包含两个组。使用增量变量复制excel行中的每个匹配组的VBA脚本是什么?

EN

回答 1

Stack Overflow用户

发布于 2017-06-07 13:05:57

不对您的正则表达式模式进行任何更改。使用以下方法,您可以遍历每个匹配的组:

代码语言:javascript
复制
str="pls18244a.lam64*fra-pth (PI000581)pls18856a.10ge*fra-pth (PI0005AW)pls25040a.10ge*fra-pth (IIE0004WK)pls27477a.10ge*fra-pth (WL050814)pls22099a.stm4*par-pth (PI0005TE)"
Set objReg = New RegExp
objReg.IgnoreCase=False
objReg.Global=True
objReg.Pattern = "(pls[a-zA-Z0-9 .*-]*) \(([A-Z 0-9]*)\)"
Set objMatches = objReg.Execute(str)
For Each match In objMatches             'The variable match will contain the full match
    a= match.Submatches.Count            'total number of groups in the full match  
    For i=0 To a-1
        MsgBox match.Submatches.Item(i)  'display each group
    Next
Next
Set objReg = Nothing
票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44401036

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档