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

VBA之正则表达式(42)-- 提取代码中变量名称

实例需求:待处理代码段如下所示,现在需要提取其中的变量名称。

Public pFactor As Integer
Sub TestCode()
Dim reg As New RegExp, a As Workbook
Dim ms As VBScript_RegExp_55.MatchCollection
Dim m As VBScript_RegExp_55.Match
Dim i, j
Dim x1, y1, z1 As String
Dim x2 As String, y2, z2
Dim x3, y3 As String, z3
Dim x4 As String, y4 As String, z4
Dim i2$, j2&, k2#
Const PRE_RATE = 2.5
End Sub

示例代码如下。

Sub Demo()Dim sText, objRegexp, objMH, objMHs, objMHVars, objMHVarsText = Trim([a1])Set objRegexp = CreateObject("vbscript.regexp")objRegexp.IgnoreCase = TrueobjRegexp.Global = TrueobjRegexp.Pattern = "\b(?:Public|Private|Static|Const|Dim)\b(.+)"Set objMHs = objRegexp.Execute(sText)objRegexp.Pattern = "(\w+)[^,]*"For Each objMH In objMHsSet objMHVars = objRegexp.Execute(objMH.submatches(0))For Each objMHVar In objMHVarsDebug.Print objMHVar.submatches(0)NextNextSet objMH = NothingSet objMHs = NothingSet objMHVars = NothingSet objMHVar = NothingSet objRegexp = Nothing
End Sub

【代码解析】
第3行代码读取待处理文本。
第4行代码创建正则对象。
第5行代码设置正则匹配忽略字符大小写。
第6行代码设置正则全局匹配。
第5行代码设置正则匹配模式。

正则表达式说明
`\b(?:PublicPrivate
(.+)匹配至少一个任意字符,第一个匹配组

匹配结果如下图所示。
在这里插入图片描述

第8第行代码执行正则匹配。
第9行代码设置第2此正则匹配模式。

正则表达式说明
(\w+)匹配至少一个(数字、字母、下划线)字符,第一个匹配组
[^,]*匹配非逗号字符,可以不存在

匹配结果如下图所示。
在这里插入图片描述

第10~15行代码循环遍历匹配结果。
第11第行代码再次执行正则匹配。
第12~14行代码循环遍历第2次匹配结果,第13行代码输入匹配结果。

http://www.lryc.cn/news/90052.html

相关文章:

  • Unity Lightmapping Setting
  • Android 12.0Camera2 静音时拍照去掉快门声音
  • Win11硬盘分区
  • 访客管理系统:Lobby Track Crack
  • Lidar AI Solution环境配置
  • 子串--子字符串 0528
  • 大数据教程【01.04】--excel的使用
  • Java输入输出流
  • 1688商品ID采集一件代发详情页面数据
  • 丽江“美丽县城”建设,高精度地籍免像控案例分享
  • 我是如何精通软件工程的
  • 如何使用 Python Nornir 实现基于 CLI 的网络自动化?
  • 并发编程的三大特性之有序性
  • LeetCode:相交链表(java)
  • 利用PHP导出MySQL数据表结构和SQL文件
  • 接口测试框架分析
  • spring boot日志
  • 【Vue2.0源码学习】虚拟DOM篇-Vue中的DOM-更新子节点
  • rsync
  • javascript:void(0)
  • ThingsBoard教程(五三):规则节点解析 Kafka Node, MQTT Node
  • 基于PHP实现的网上留言管理系统的设计
  • 【9 Vue全家桶 – Vuex状态管理】
  • Oracle游标学习
  • 几种常用的正则表达式
  • 华为OD机试真题 Java 实现【快速开租建站】【2023Q1 200分】,附详细解题思路
  • 照片中对象识别模型YOLOv3在iOS项目中的浅析与使用
  • Caffeine 本地高速缓存工具类
  • 加密解密软件VMProtect教程(八)许可制度之序列号生成器
  • 单源最短路的建图