excel vba 正则表达式 从实例开始

excel vba 正则表达式 从实例开始

ID:12479535

大小:35.73 KB

页数:23页

时间:2018-07-17

excel vba 正则表达式 从实例开始_第1页
excel vba 正则表达式 从实例开始_第2页
excel vba 正则表达式 从实例开始_第3页
excel vba 正则表达式 从实例开始_第4页
excel vba 正则表达式 从实例开始_第5页
资源描述:

《excel vba 正则表达式 从实例开始》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、'EXCELVBA正则表达式从实例开始所有代码都测试过'''[2011-09-09:http://www.cnblogs.com/dxy1982/archive/2011/09/09/2159246.html]'[2010-08-08:http://www.excelpx.com/thread-137472-1-1.html]'数据验证经常出现的情况是,需要验证和处理大量的文本内容,有时候需要查找字符串,有时候要按条件替换,并且这些待处理的问题还是有一定的规律可循的,但是无法通过枚举的方式挨个验证,这个时候就需要正则表达式来帮忙。

2、'1.正则表达式(RegularExpression)基础'  正则表达式是通用的文本搜索和处理方案,它的知识不是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

3、中的正则表达式应用'  在VBA中使用正则表达式,可以通过下列途径实现:'创建正则表达式对象:'前期绑定:在VBA代码编辑器中的"Tools"菜单中,选中"References...",然后引用MicrosoftVBScriptRegularExpressions5.5类库,然后直接定义对象:DimregAsNewRegExp。'后期绑定:使用CreateObject方法定义对象:CreateObject("VBSCRIPT.REGEXP")。'前一种方式的优点是可以有编辑器的Intellisense支持?'RegExp对象的属性

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

5、e。'Pattern-设置或返回被搜索的正则表达式模式。被搜索的正则字符串表达式。它包含各种正则表达式字符。'RegExp对象的方法:'Execute-对指定的字符串执行正则表达式搜索。需要传入要在其上执行正则表达式的文本字符串。正则表达式搜索的设计模式是通过RegExp对象的Pattern来设置的。Execute方法返回一个Matches集合,其中包含了在string中找到的每一个匹配的Match对象。如果未找到匹配,Execute将返回空的Matches集合。'Replace-替换在正则表达式查找中找到的文本?'Test-对指

6、定的字符串执行一个正则表达式搜索,并返回一个Boolean值指示是否找到匹配的模式。RegExp.Global属性对Test方法没有影响。如果找到了匹配的模式,Test方法返回True;否则返回False。'MatchCollection对象与Match对象'匹配到的所有对象放在MatchCollection集合中,这个集合对象只有两个只读属性:'Count:匹配到的对象的数目'Item:集合的又一通用方法,需要传入Index值获取指定的元素。'一般,可以使用ForEach语句枚举集合中的对象。集合中对象的类型是Match。'Ma

7、tch对象有以下几个只读的属性:'FirstIndex-匹配字符串在整个字符串中的位置,值从0开始。'Length-匹配字符串的长度?'Value-匹配的字符串?'SubMatches-集合,匹配字符串中每个分组的值。作为集合类型,有Count和Item两个属性。''常用的正则表达式主要有以下几种:'匹配中文字符的正则表达式:[u4e00-u9fa5]'评注:匹配中文还真是个头疼的事,有了这个表达式就好办了'匹配双字节字符(包括汉字在内):[^x00-xff]'评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASC

8、II字符计1)'匹配空白行的正则表达式:s*r'评注:可以用来删除空白行'匹配HTML标记的正则表达式:<(S*?)[^>]*>.*?

9、<.*?/>'评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。