`
啸笑天
  • 浏览: 3469228 次
  • 性别: Icon_minigender_1
  • 来自: China
社区版块
存档分类
最新评论

EXCEL VBA 正则表达式

    博客分类:
  • vba
 
阅读更多

 

数据验证经常出现的情况是,需要验证和处理大量的文本内容,有时候需要查找字符串,有时候要按条件替换,并且这些待处理的问题还是有一定的规律可循的,但是无法通过枚举的方式挨个验证,这个时候就需要正则表达式来帮忙。

1.正则表达式(Regular Expression)基础
  正则表达式是通用的文本搜索和处理方案,它的知识不是VBA独有的,基本上每种语言都内置了正则表达式的功能。正则表达式的基础知识不是这里的重点,需要的朋友可以Google一下,或者参看下面的一些入门教程:
http://deerchao.net/tutorials/regex/regex.htm
http://www.regexlab.com/zh/regref.htm
http://www.williamlong.info/archives/433.html

2.VBA中的正则表达式应用
  在VBA中使用正则表达式,可以通过下列途径实现:
创建正则表达式对象:
前期绑定:在VBA代码编辑器中的"Tools"菜单中,选中"References...",然后引用Microsoft VBScript Regular Expressions 5.5类库,然后直接定义对象:Dim reg As New RegExp。
后期绑定:使用CreateObject方法定义对象:CreateObject("VBSCRIPT.REGEXP")。
前一种方式的优点是可以有编辑器的Intellisense支持。

RegExp对象的属性:
Global
 - 设置或返回一个 Boolean 值,该值指明在整个搜索字符串时模式是全部匹配还是只匹配第一个。如果搜索应用于整个字符串,Global 属性的值应该为 True,否则其值为 False。默认的设置为True。
Multiline - 返回正则表达式是否具有标志m, 缺省值为False。如果指定的搜索字符串分布在多行,这个属性是要设置为True的。
IgnoreCase - 设置或返回一个Boolean值,指明模式搜索是否区分大小写。如果搜索是区分大小写的,则 IgnoreCase 属性应该为False;否则应该设为True。缺省值为True。
Pattern - 设置或返回被搜索的正则表达式模式。 被搜索的正则字符串表达式。它包含各种正则表达式字符。

RegExp对象的方法:
Execute
 - 对指定的字符串执行正则表达式搜索。需要传入要在其上执行正则表达式的文本字符串。正则表达式搜索的设计模式是通过 RegExp对象的Pattern来设置的。Execute方法返回一个Matches集合,其中包含了在string中找到的每一个匹配的Match对 象。如果未找到匹配,Execute将返回空的Matches集合。
Replace - 替换在正则表达式查找中找到的文本。
Test - 对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。RegExp.Global属性对Test方法没有影响。如果找到了匹配的模式,Test方法返回True;否则返回False。

MatchCollection对象与Match对象
匹配到的所有对象放在MatchCollection集合中,这个集合对象只有两个只读属性:
Count:匹配到的对象的数目
Item:集合的又一通用方法,需要传入Index值获取指定的元素。

一般,可以使用For Each语句枚举集合中的对象。集合中对象的类型是Match。
Match对象有以下几个只读的属性:
FirstIndex - 匹配字符串在整个字符串中的位置,值从0开始。
Length - 匹配字符串的长度。
Value - 匹配的字符串。
SubMatches - 集合,匹配字符串中每个分组的值。作为集合类型,有Count和Item两个属性。

结尾两个示例:
' 正则表达式示例1 提取字符串中的数字
Sub getNum1()
    ' 这种使用方式需要"工具""引用"
    ' 引用Microsoft VBScript Regular Expressions 5.5类库
    Dim reg As New RegExp
    With reg
        .Global = True
        .IgnoreCase = True
        .Pattern = "\d+"
    End With
    
   Dim mc As MatchCollection
   Dim m As Match
   Set mc = reg.Execute("123aaaaa987uiiui999")
   For Each m In mc
    MsgBox m.Value + 1
   Next
End Sub
' 正则表达式示例2 用"字符串"替换原字符串中符合匹配模式的部分
Sub getNum2()
    Dim arr
    arr = Split("A12B-R1E2W-E1T-R2T-Q1B2Y3U4D", "-") ' split(字符串,"分隔符")拆分字符串
    MsgBox "arr(0)=" & arr(0) & ";arr(1)=" & arr(1)
    MsgBox Join(arr, ",") ' join(数组,"分隔符")用分隔连接数组的每个元成一个字符串
    
    Dim arrStr() As String
    ReDim arrStr(LBound(arr) To UBound(arr)) ' 为动态数组分配存储空间
    With CreateObject("VBSCRIPT.REGEXP") ' 生成一个正则表达式对象实例
        For i = LBound(arr) To UBound(arr)
            .Global = True ' 设置全局可用,即替换所有符合匹配模式的字符串
            .Pattern = "[^A-Z]" ' 匹配模式为非大写字母
            arrStr(i) = .Replace(arr(i), "") ' 将arr(i)字符串中符合匹配模式的部分替换为空字符
        Next
    End With
    Cells.ClearContents
    Cells(1, 1).Resize(UBound(arr) + 1, 1) = Application.WorksheetFunction.Transpose(arrStr())
End Sub


他那代码没看,自己用到写了下
'<body>タグに onLoad="commonOnload()"があるか。
Private Function SubCheckBodyCommonOnload(pageStr)
         Dim reg As Object
         Set reg = CreateObject("VBscript.RegExp")
            With reg
                .Global = True
                .IgnoreCase = True
                .Pattern = "(<)([\s]*)(body)([\w\W]*)(onLoad)([\s]*)=([\s]*)(\W)([\s]*)(commonOnload\()([\s]*)(\))"
            End With
            
        SubCheckBodyCommonOnload = reg.test(pageStr)
End Function
 
分享到:
评论

相关推荐

    Excel VBA 正则表达式视频教程

    001_正则表达式初体验.wmv 002_什么是正则表达式.wmv 003_实例(统计出现次数) .wmv 004_实例(文本替换).wmv 005_正则表达式之元字符.wmv 006_正则表达式元字符提取数据.wmv 007_正则表达式元字符整理数据.wmv 008_...

    vba正则表达式基础

    vba正则表达式基础知识介绍,由浅入深,实例讲解

    EXCEL-VBA-正则表达式-从实例开始.docx

    ### EXCEL-VBA-正则表达式-从实例开始 #### 一、正则表达式基础知识 正则表达式(Regular Expression),简称“regex”或“regexp”,是一种强大的文本模式匹配工具,广泛应用于多种编程语言中,用于进行复杂的...

    EXCEL使用正则表达式.rar

    正则表达式在Excel中的应用主要通过VBA(Visual Basic for Applications)实现,VBA是Excel内置的编程环境,用户可以编写宏来执行自定义操作。例如,可以创建自定义函数,用于匹配、提取或替换符合特定模式的文本。...

    正则表达式入门与提高---整理版_VBa_正则式_

    在VBA(Visual Basic for Applications)环境中,正则表达式可以极大地增强你在Excel、Word等Office应用中的数据处理能力。这篇整理版的文章将帮助初学者快速入门,并提升对正则表达式的理解。 首先,我们要了解...

    (完整word版)EXCELVBA正则表达式学习.doc

    8、正则表达式在 Excel VBA 中的应用场景: - 数据清洗:可以快速批量地清理格式不一致的数据,如电话号码的例子所示。 - 数据提取:从长文本中提取特定的信息,比如邮箱地址、日期等。 - 数据验证:检查输入是否...

    VBA中的正则表达式

    VBA中的正则表达式,正则表达式的基本知识讲解!

    EXCEL中用正则表达式

    Excel本身并不直接支持正则表达式,但可以通过VBA(Visual Basic for Applications)扩展其功能。 VBA是Excel内置的编程环境,它允许用户编写自定义函数和宏,以实现更高级的操作。在VBA中,我们可以引入`MS ...

    wps正则表达式 以及 wps通过正则表达式验证手机号码

    在Excel表格处理中,正则表达式是一种强大的文本匹配工具,可以帮助我们进行复杂的数据验证、查找和替换操作。虽然默认情况下,WPS Excel并不直接支持正则表达式,但通过其自定义函数功能,我们可以创建自己的函数来...

    excel 中 正则表达式资料

    虽然Excel自身并不直接支持正则表达式,但通过VBA(Visual Basic for Applications)宏,我们可以引入正则表达式的功能。VBA是Excel内置的一种编程语言,允许用户自定义函数、过程和增强Excel的功能。 正则表达式由...

    正则表达式替换文本_everyrk3_正则表达式_正则表达式替换文本_

    以Excel为例,`正则表达式替换文本.xlsm`可能是一个包含VBA宏的工作簿,用于在Excel单元格中进行正则替换。用户可以输入正则表达式和替换文本,然后应用到选定的范围,这对于处理大量数据非常有用。 在实际应用中,...

    EXCEL正则表达式自定义函数

    本VBA模块是实现“正则表达式”功能的自定义函数模块,各自定义函数在公式向导窗口均有功能及参数说明,方便、易用;在VBA集成环境导入本模块文件后便可使用。

    正则表达式提取文本.bas

    excel自定义函数,在指定文本中使用正则表达式提取其中的符合文本并以指定分隔符分隔,如:文本:a1b2c3d4 正则:\d 分隔符:| 结果:1|2|3|4

    vba 正规表达式应用

    VBA(Visual Basic for Applications)是...通过这些基础和进阶的正则表达式知识,VBA能够帮助我们在Excel或其他Office组件中处理大量文本数据,提高工作效率。记住,熟练掌握正则表达式是提升VBA编程能力的关键之一。

    支持正则表达式的Excel_v100_220415A

    压缩包中的文件“支持正则表达式的Excel_v100_220415A.xlsm”是一个启用宏的Excel文件,这意味着其中包含了自定义的VBA(Visual Basic for Applications)代码,可能就是实现正则表达式功能的部分。VBA是Excel内置的...

    Excel正则工具v1.3.1.zip

    Excel正则工具 (总有你需要的功能!)正则表达式是对字符串和特殊字符操作的一种...在Excel中使用正则表达式,一般只能在VBA中调用,要求比较高。今天我要向大家介绍一个方法,让大家在Excel中也能使用正则表达式。

    Excel VBA数据验证与正则表达式汇总整理-VBA源码.rar

    在Excel VBA编程中,数据验证和正则表达式是两个非常重要的概念,它们在处理和分析大量数据时起着至关重要的作用。VBA(Visual Basic for Applications)是Microsoft Office套件中的内置脚本语言,它允许用户自定义...

    VBA正则提取A字符串之后B字符串之前中间的内容.txt

    VBA正则提取A字符串之后B字符串之前中间的内容.txt

    正则表达式与连接access 相对路径

    以下是一个例子,展示如何在VBA中使用正则表达式检查Access相对路径的正确性: ```vba Sub CheckRelativePath() Dim regEx As Object Dim strPattern As String Dim strInput As String Dim strPath As String ...

Global site tag (gtag.js) - Google Analytics