在VBA中处理字符串(基本操作篇1)
在VBA中处理字符串(基本操作篇1)
- - - - - - - - - - - - - - -
- - - - - - - - - - - - - - -
2
VBA中处理字符串的函数
2.1 比较字符串
通常,在VBA中进行字符串比较时,会用到比较运算符(如=、>等)、Like运算符和StrComp函数。此外,在模块的开头用Option
Compare语句指定比较方式。
2.1.1 比较运算符
可以采用简单的逻辑运算符进行两个字符串的比较,即
<(小于)、<=(小于或等于)、>(大于)、>=(大于或等于)、=(等于)、<>(不等于)。此外,还可以使用Like运算符进行比较。
2.1.2 StrComp函数
StrComp函数返回字符串比较的结果。其语法为:StrComp(string1,string2[,compare])
其中,参数string1和strng2为必需的参数,可以是任何有效的字符串表达式。
参数Compare为可选参数,如果该参数为Null,将发生错误。如果参数Compare设置为常数vbUseCompareOption或-1或忽略该参数,将使用Option
Compare语句设置进行比较;如果忽略该参数且没有设置Option
Compare语句,则按二进制进行比较;如果参数Compare设置为常数vbBinaryCompare或0,则用二进制进行比较;如果参数Compare设置为常数vbTextCompare或1,则按文本进行比较;如果参数Compare设置为常数vbDatabaseCompare 或2,此时仅适用于Microsoft
Access,进行基于数据库信息的比较。
StrComp函数的返回值为:如果String1<String2,则返回值为-1;如果String1=String2,则返回值为0;如果
String1>String2,则返回值为1;如果String1或String2为Null,则返回值为Null。
看看下面的示例:
Sub testStringCompare()
Dim MyStr1 As String, MyStr2 As String, MyComp1, MyComp2, MyComp3, MyComp4
MyStr1 = "ABCD"
MyStr2 = "abcd"
MyComp1 = StrComp(MyStr1, MyStr2,
1) ' 返回
MyComp2 = StrComp(MyStr1, MyStr2,
0) ' 返回
-1
MyComp3 = StrComp(MyStr1,vb 字符串转数组
MyStr2) ' 返回
-1
MyComp4 = StrComp(MyStr2,
MyStr1)
'返回1
MsgBox "StrComp(MyStr1, MyStr2, 1)的结果为:" & MyComp1
MsgBox "StrComp(MyStr1, MyStr2, 0)的结果为:" & MyComp2
MsgBox "StrComp(MyStr1, MyStr2)的结果为:" & MyComp3
MsgBox "StrComp(MyStr2, MyStr1)的结果为:" & MyComp4
End Sub
示例说明:如果StrComp函数的第三个参数值为1,则以文本比较的方式进行字符串比较;如果第三个参数值为0或忽略该参数,则以二进制比较的方式进行字符串比较。注意,文本比较的方式不区分字母大小写,而二进制比较方式则区分大小写。
[编程方法和技巧] 完成一次简单的单一比较,如
If UCase(sString1)<UCase(sString2) Then
比使用StrComp函数:
If StrComp(sString1,sString2,vbTextCompare)=-1 Then
在性能上要提高30%,且更容易阅读和理解。
2.2 转换字符串
2.2.1 StrConv函数
使用StrConv函数来按指定类型转换字符串。其语法为:StrConv(string,conversion,LCID)
其中,参数string为要转换的字符串,参数conversion为指定转换的类型,参数LCID为可选参数。
如果将参数conversion设置为vbUpperCase或1,则将字符串转换成大写;设置为vbLowerCase或2,则将字符串转换成小写;设置为vbProperCase或3,则将字符串中每个字的开头字母转换成大写;设置为vbUnicode或64,则根据系统的缺省码页将字符串转换成Unicode;设置为vbFromUnicode 或128,则将字符串由Unicode转换成系统的缺省码页。
在将ANSI格式的Byte数组转换成字符串时,应使用StrConv 函数;转换Unicode格式的数组时,使用赋值语句。下面的例子使用StrConv函数将Unicode字符串转换成ANSI字符串:
Sub testConverseString()
Dim i As Long
Dim x() As Byte
x = StrConv("ABCDEFG",
vbFromUnicode) '
转换字符串。
For i = 0 To UBound(x)
Debug.Print
x(i)
Next
End Sub
下面的例子将句子中每个词语的首字母转换为大写:Sub testConverseString2()
Debug.Print StrConv("my book is this book.", vbProperCase)
End Sub
程序运行后,在VBE窗口中的立即窗口中将会看到上述结果。
下面的示例演示了如何把一个字符串转换为字节数组,以便使用在API函数调用中:
Sub Test()
Dim byArray() As Byte
Dim sString As String
sString = "Some stuff"
byArray = StrConv(sString, vbFromUnicode)
End Sub
StrConv函数将下面的字符看成是字的分隔符:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论