RegExp对象的详细用法

转载 2006年06月12日 15:19:00

RegExp对象提供简单的正则表达式支持功能。

  RegExp对象的用法:
Function RegExpTest(patrn, strng)
Dim regEx, Match, Matches ' 建立变量。
Set regEx = New RegExp ' 建立正则表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = True ' 设置是否区分字符大小写。
regEx.Global = True ' 设置全局可用性。
Set Matches = regEx.Execute(strng) ' 执行搜索。
For Each Match in Matches ' 遍历匹配集合。
RetStr = RetStr & "Match found at position "
RetStr = RetStr & Match.FirstIndex & ". Match Value is '"
RetStr = RetStr & Match.Value & "'." & vbCRLF
Next
RegExpTest = RetStr
End Function

MsgBox(RegExpTest("is.", "IS1 is2 IS3 is4"))

  RegExp 对象的属性

  ◎ Global属性

  Global属性设置或返回一个 Boolean 值,该值指明在整个搜索字符串时模式是全部匹配还是只匹配第一个。
  语法
object.Global [= True | False ]
  object 参数总是 RegExp 对象。如果搜索应用于整个字符串,Global 属性的值为 True,否则其值为 False。默认的设置为 True。

  Global 属性的用法(改变赋予 Global 属性的值并观察其效果):
Function RegExpTest(patrn, strng)
Dim regEx ' 建立变量。
Set regEx = New RegExp ' 建立规范表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = True ' 设置是否区分字母的大小写。
regEx.Global = True ' 设置全程性质。
RegExpTest = regEx.Execute(strng) ' 执行搜索。
End Function

MsgBox(RegExpTest("is.", "IS1 is2 IS3 is4"))

  ◎ IgnoreCase属性

  IgnoreCase属性设置或返回一个Boolean值,指明模式搜索是否区分大小写。
  语法
object.IgnoreCase [= True | False ]
  object 参数总是一个 RegExp 对象。如果搜索是区分大小写的,则 IgnoreCase 属性为 False;否则为 True。缺省值为 True。

  IgnoreCase 属性的用法(改变赋予 IgnoreCase 属性的值以观察其效果):
Function RegExpTest(patrn, strng)
Dim regEx ' 建立变量。
Set regEx = New RegExp ' 建立正则表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = True ' 设置是否区分大小写。
RegExpTest = regEx.Execute(strng) ' 执行搜索。
End Function

MsgBox(RegExpTest("is.", "IS1 is2 IS3 is4"))

  ◎ Pattern属性

  Pattern属性设置或返回被搜索的正则表达式模式。
  语法
object.Pattern [= "searchstring"]
Pattern 属性的语法包含以下几个部分:

  语法说明:
object 必需的。总是一个 RegExp 对象变量。
searchstring 可选的。被搜索的正则字符串表达式。它可能包含设置部分表格中的各种正则表达式字符。

  设置
  在书写正则表达式的模式时使用了特殊的字符和序列。下面描述了可以使用的字符和序列,并给出了实例。
 / 将下一个字符标记为特殊字符或字面值。例如"n"与字符"n"匹配。"/n"与换行符匹配。序列"//"与"/"匹配对面,"/("与"("匹配。
 ^ 匹配输入的开始位置。
 $ 匹配输入的结尾。
 * 匹配前一个字符零次或几次。例如,"zo*"可以匹配"z"、"zoo"。
 + 匹配前一个字符一次或多次。例如,"zo+"可以匹配"zoo",但不匹配"z"。
 ? 匹配前一个字符零次或一次。例如,"a?ve?"可以匹配"never"中的"ve"。
 . 匹配换行符以外的任何字符。
 (pattern) 与模式匹配并记住匹配。匹配的子字符串可以从作为结果的 Matches 集合中使用 Item [0]...[n]取得。如果要匹配括号字符(和 ),可使用"/(" 或 "/)"。
 x|y 匹配 x 或 y。例如 "z|food" 可匹配 "z" 或 "food"。"(z|f)ood" 匹配 "zoo" 或 "food"。
 {n} n 为非负的整数。匹配恰好n次。例如,"o{2}" 不能与 "Bob 中的 "o" 匹配,但是可以与"foooood"中的前两个o匹配。
 {n,} n 为非负的整数。匹配至少n次。例如,"o{2,}"不匹配"Bob"中的"o",但是匹配"foooood"中所有的o。"o{1,}"等价于"o+"。"o{0,}"等价于"o*"。
 {n,m} m 和 n 为非负的整数。匹配至少 n 次,至多 m 次。例如,"o{1,3}" 匹配 "fooooood"中前三个o。"o{0,1}"等价于"o?"。
 [xyz] 一个字符集。与括号中字符的其中之一匹配。例如,"[abc]" 匹配"plain"中的"a"。
 [^xyz] 一个否定的字符集。匹配不在此括号中的任何字符。例如,"[^abc]" 可以匹配"plain"中的"p".
 [a-z] 表示某个范围内的字符。与指定区间内的任何字符匹配。例如,"[a-z]"匹配"a"与"z"之间的任何一个小写字母字符。
 [^m-z] 否定的字符区间。与不在指定区间内的字符匹配。例如,"[m-z]"与不在"m"到"z"之间的任何字符匹配。
 /b 与单词的边界匹配,即单词与空格之间的位置。例如,"er/b" 与"never"中的"er"匹配,但是不匹配"verb"中的"er"。
 /B 与非单词边界匹配。"ea*r/B"与"never early"中的"ear"匹配。
 /d 与一个数字字符匹配。等价于[0-9]。
 /D 与非数字的字符匹配。等价于[^0-9]。
 /f 与分页符匹配。
 /n 与换行符字符匹配。
 /r 与回车字符匹配。
 /s 与任何白字符匹配,包括空格、制表符、分页符等。等价于"[ /f/n/r/t/v]"。
 /S 与任何非空白的字符匹配。等价于"[^ /f/n/r/t/v]"。
 /t 与制表符匹配。
 /v 与垂直制表符匹配。
 /w 与任何单词字符匹配,包括下划线。等价于"[A-Za-z0-9_]"。
 /W 与任何非单词字符匹配。等价于"[^A-Za-z0-9_]"。
 /num 匹配 num个,其中 num 为一个正整数。引用回到记住的匹配。例如,"(.)/1"匹配两个连续的相同的字符。
 /n 匹配 n,其中n 是一个八进制换码值。八进制换码值必须是 1, 2 或 3 个数字长。例如,"/11" 和 "/011" 都与一个制表符匹配。"/0011"等价于"/001" 与 "1"。八进制换码值不得超过 256。否则,只有前两个字符被视为表达式的一部分。允许在正则表达式中使用ASCII码。
 /xn 匹配n,其中n是一个十六进制的换码值。十六进制换码值必须恰好为两个数字长。例如,"/x41"匹配"A"。"/x041"等价于"/x04" 和 "1"。允许在正则表达式中使用 ASCII 码。

  Pattern 属性的用法:
Function RegExpTest(patrn, strng)
Dim regEx ' 建立变量。
Set regEx = New RegExp ' 建立正则表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = True ' 设置是否区分大小写。
RegExpTest = regEx.Execute(strng) ' 执行搜索。
End Function

MsgBox(RegExpTest("is.", "IS1 is2 IS3 is4"))

  RegExp对象的方法

  ◎ Execute方法

  Execute方法对指定的字符串执行正则表达式搜索。
  语法
object.Execute(string)
  语法部分描述
object 必需的。总是一个 RegExp 对象的名称。
string 必需的。要在其上执行正则表达式的文本字符串。

  说明
  正则表达式搜索的设计模式是通过 RegExp 对象的 Pattern 来设置的。
  Execute 方法返回一个 Matches 集合,其中包含了在 string 中找到的每一个匹配的 Match 对象。如果未找到匹配,Execute 将返回空的 Matches 集合。

  Execute 方法的用法:
Function RegExpTest(patrn, strng)
Dim regEx ' 建立变量。
Set regEx = New RegExp ' 建立正则表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = False ' 设置区分大小写。
regEx.Global = True ' 搜索全部匹配。
RegExpTest = regEx.Execute(strng) ' 执行搜索。
End Function

MsgBox(RegExpTest("is.", "IS1 is2 IS3 is4"))

  ◎ Replace方法

  Replace方法替换在正则表达式查找中找到的文本。
  语法
object.Replace(string1, string2)
  语法部分描述
object 必需的。总是一个 RegExp 对象的名称。
string1 必需的。string1 是将要进行文本替换的字符串。
string2 必需的。 string2 是替换文本字符串。

  说明
  被替换的文本的实际模式是通过 RegExp 对象的 Pattern 属性设置的。
  Replace 方法返回 string1 的副本,其中的 RegExp.Pattern 文本已经被替换为 string2。如果没有找到匹配的文本,将返回原来的 string1 的副本。

  eplace 方法的用法:
Function ReplaceTest(patrn, replStr)
Dim regEx, str1 ' 建立变量。
str1 = "The quick brown fox jumped over the lazy dog."
Set regEx = New RegExp ' 建立正则表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = True ' 设置是否区分大小写。
ReplaceTest = regEx.Replace(str1, replStr) ' 作替换。
End Function

MsgBox(ReplaceTest("fox", "cat"))
' 将 'fox' 替换为 'cat'。

;另外,Replace 方法在模式中替换 subexpressions 。 下面对以前示例中函数的调用,替换了原字符串中的所有字对:
MsgBox(ReplaceText("(/S+)(/s+)(/S+)", "$3$2$1")) ' Swap pairs of words.

  ◎ Test方法

  Test方法对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。
  语法
object.Test(string)
  语法部分描述
object 必需的。总是一个 RegExp 对象的名称。
string 必需的。要执行正则表达式搜索的文本字符串。

说明
  正则表达式搜索的实际模式是通过RegExp对象的Pattern属性来设置的。RegExp.Global属性对Test方法没有影响。
  如果找到了匹配的模式,Test方法返回True;否则返回False。

  Test 方法的用法:
Function RegExpTest(patrn, strng)
Dim regEx, retVal ' 建立变量。
Set regEx = New RegExp ' 建立正则表达式。
regEx.Pattern = patrn ' 设置模式。
regEx.IgnoreCase = False ' 设置是否区分大小写。
retVal = regEx.Test(strng) ' 执行搜索测试。
If retVal Then
RegExpTest = "找到一个或多个匹配。"
Else
RegExpTest = "未找到匹配。"
End If
End Function

MsgBox(RegExpTest("is.", "IS1 is2 IS3 is4"))

RegExp对象的使用与正则替换

相信大家应该都有做过这样的题目。就是把一个数字转测
  • kelvinbean
  • kelvinbean
  • 2015年07月23日 16:20
  • 339

RegExp对象的属性

RegExp对象的属性分为静态属性和实例属性。 一 静态属性 RegExp对象的静态属性包含:input、multiline、lastMatch、lastParen、leftContext、rig...
  • chengqiuming
  • chengqiuming
  • 2017年04月12日 10:33
  • 785

RegExp对象方法

test()方法:该方法用于检测一个字符串是否匹配某个模式;  基本语法:RegExpObject.test(str);    @param(参数) str是需要检测的字符串;    @retu...
  • heyue_99
  • heyue_99
  • 2016年12月06日 18:23
  • 531

详述RegExp的使用

正则表达式 //test方法,测试字符串,符合模式时返回true,否则返回false var re = /he/;//最简单的正则表达式,将匹配he...
  • qin9r3y
  • qin9r3y
  • 2014年05月04日 15:23
  • 2301

RegExp 使用说明

一:正则表达式的创建方式   1.文字格式,使用方法如下:   /pattern/flags(即:/模式/标记)   2.RegExp构造函数,使用方法如下:   new RegExp("pa...
  • qbook
  • qbook
  • 2014年03月13日 15:14
  • 8832

js中使用正则表达式(三)RegExp对象构造函数属性介绍

1、RegExp构造函数属性可以通过两种方式访问:长属性名和短属性名方式,其属性有: 长属性名 短属性名 说明 input $_ 最近一次要匹配的字符串,...
  • javaloveiphone
  • javaloveiphone
  • 2015年09月22日 10:06
  • 1262

RegExp对象的exec方法应用

一 介绍 用正则表达式模式在字符串中运行查找,并返回包含该查找结果的一个数组。 语法: rgExp.exec(str) rgExp:必选项。包含正则表达式模式和可用标志的正则表达式对象。 S...
  • chengqiuming
  • chengqiuming
  • 2017年04月12日 10:34
  • 166

tcl/tk参考——字符串操作regexp

.. 名称regexp - 为一个字符串进行正则表达式匹配 语法regexp ?switches? exp string ?matchVar? ?subMatchVar subMatchVar ......
  • dulixin
  • dulixin
  • 2008年04月20日 14:04
  • 19221

SQL中的正则表达式(REGEXP)

   SQL的查询语句中,有时会需要引进正则表达式为其复杂搜索指定模式。下面给出一些Regexp在MYSQL语句中应用(非全部): 1) ^匹配字符串的开始部分。mysql> SELECT fo/nf...
  • mini_snow
  • mini_snow
  • 2008年10月23日 00:46
  • 15858

sql regexp的使用

正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较。 MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据。 My...
  • u013061183
  • u013061183
  • 2017年07月21日 12:09
  • 1381
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:RegExp对象的详细用法
举报原因:
原因补充:

(最多只允许输入30个字)