Like和Is运算符

5 篇文章 0 订阅

 

Like    Is

 

Like 运算符

 

用来比较两个字符串。

 

语法

 

result = string Like pattern

 

Like 运算符的语法具有以下几个部分:

 

部分 描述

result 必需的;任何数值变量。

string 必需的;任何字符串表达式。

pattern 必需的;任何字符串表达式,遵循“说明”中的模式匹配约定。

 

说明

 

如果 string pattern 匹配,则 result True;如果不匹配,则 result False。但是如果 string pattern 中有一个为 Null,则 result Null

 

Like 运算符的特性随着 Option Compare 语句而不同。每个模块的缺省字符串比较方法是 Option Compare Binary

 

在字符串比较中,Option Compare Binary 的结果是根据字符的内部二进制表示法导出的排序顺序得到的。在 Microsoft Windows 中,排序顺序由代码页决定。

 

在字符串比较中,Option Compare Text 的结果是字符串比较,它建立在不区分大小写的文本排序顺序基础上,而这一排序顺序是由系统的国别确定的。

 

内建的模式匹配功能提供了多种工具来进行字符串比较。有了模式匹配功能就可以使用通配符、字符串列表或字符区间的任何组合来匹配字符串。下列表格指出 pattern 中允许的字符以及它们与什么进行匹配:

 

pattern 中的字符 符合 string 中的

? 任何单一字符。

* 零个或多个字符。

# 任何一个数字 (09)

[charlist] charlist.中的任何单一字符。

[!charlist] 不在 charlist 中的任何单一字符。

 

在中括号 ([ ]) 中,可以用由一个或多个字符 (charlist) 组成的组与 string 中的任一字符进行匹配,这个组几乎包括任何一个字符代码以及数字。

 

注意 为了与左括号 ([)、问号 (?)、数字符号 (#) 和星号 (*) 等特殊字符进行匹配,可以将它们用方括号括起来。不能在一个组内使用右括号 (]) 与自身匹配,但在组外可以作为个别字符使用。

 

通过在范围的上、下限之间用连字符 ()charlist 可以指定字符的范围。例如,如果 string 中相应字符的位置包括 AZ 之间的任意大写字母,则 [A-Z] 得到一个匹配。不需要分界符,方括号内就可以包括多个范围。

 

指定范围的意义取决于运行时的有效字符排序(正如 Option Compare 和系统的国别设置所确定的,代码在运行之中)。使用 Option Compare Binary 示例可以看到,范围 [AE] AB E 相匹配。通过 Option Compare Text 可以看到,[AE] A, a, _, _, B, b, E, e 相匹配。此范围与 _ _ 不匹配,因为按照排序顺序,重音字符在非重音字符之后。

 

下面列举的是模式匹配的其它重要规则:

 

charlist 开头的惊叹号 (!) 意味着,如果在 string 中找到任何不属于 charlist 的字符,则存在一个匹配。如果在方括号之外使用惊叹号,则惊叹号与自身匹配。

 

连字符 () 可以出现在 charlist 的开头(如果使用惊叹号,则在惊叹号之后),也可以出现在 charlist 的结尾与自身匹配。在任何其它地方,连字符用来识别字符的范围。

 

当指定了字符范围时,这些字符必须按照升序(从最小到最大)顺序来显示。[A-Z] 是有效模式,但 [Z-A] 不是。

 

字符序列 [] 被看作是长度为零的字符串 ("")

某些语言的字母表中有一些特殊字符,它们表示两个分开的字符。例如,在一些语言中,当字符 "a" "e" 同时出现时,用 "_" 来表示字符 "a" "e"Like 运算符可以辨认出单一的特殊字符和两个个别字符是否相等。

 

当一个语言使用了一个特殊字符,而且这个字符在系统地区设置中已被指定的时候,在 pattern string 中出现的单一特殊字符将与其他字符串中等价的两个字符相匹配。与此相似,由方括号括起来的 pattern 中的单一特殊字符(字符本身在列表或范围内)将与 string 中等价的两个字符序列匹配。

Like 运算符示例

本示例使用 Like 运算符做字符串的方式比较。

 

示例

 

Dim MyCheck

MyCheck = "aBBBa" Like "a*a"   ' 返回 True

MyCheck = "F" Like "[A-Z]"   ' 返回 True

MyCheck = "F" Like "[!A-Z]"   ' 返回 False

MyCheck = "a2a" Like "a#a"   ' 返回 True

MyCheck = "aM5b" Like "a[L-P]#[!c-e]"   ' 返回 True

MyCheck = "BAT123khg" Like "B?T*"   ' 返回 True

MyCheck = "CAT123khg" Like "B?T*"   ' 返回 False

 

Is 运算符

 

用来比较两个对象的引用变量。

 

语法

 

result = object1 Is object2

 

Is 运算符的语法具有以下几个部分:

 

部分 描述

result 必需的;任何数值变量。

object1 必需的;任何对象名称。

object2 必需的;任何对象名称。

 

Is 运算符示例

本示例使用 Is 运算符来比较两个对象引用。示例中的对象变量名只是作说明用途的一般性名称而已。

 

Dim MyObject, YourObject, ThisObject, OtherObject, ThatObject, MyCheck

Set YourObject = MyObject   ' 指定对象引用。

Set ThisObject = MyObject

Set ThatObject = OtherObject

MyCheck = YourObject Is ThisObject   ' 返回 True

MyCheck = ThatObject Is ThisObject   ' 返回 False

' 假设 MyObject <> OtherObject

MyCheck = MyObject Is ThatObject   ' 返回 False

  

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值