您好,欢迎访问三七文档
1VBA中的字符串2VBA中处理字符串的函数2.1比较字符串2.2转换字符串2.3创建字符串2.4获取字符串的长度2.5格式化字符串2.6查找字符串2.7提取字符/字符串2.8删除空格2.9返回字符代码2.10返回数值代表的相应字符2.11使用字节的函数2.12返回数组的函数2.13连接字符串2.14替换字符串2.15反向字符串------------------------------1VBA中的字符串VBA不仅可以处理数字,也可以处理文本(字符串)。VBA提供了两类字符串:一类为固定长度的字符串,声明时包含指字的字符数。例如,下面的语句DimstrFixedLongAsString*100声明字符串变量后,无论赋予该变量多少个字符,总是只包含100个字符,但字符串最长不超过65526个字符,且需要使用Trim函数去掉字符串中多余的空格。定长字符串只有在必要时才使用。另一类为动态字符串。例如,声明字符串变量DimstrDynamicAsString后,可以给该变量任意赋值,最多可包含20亿个字符。------------------------------2VBA中处理字符串的函数2.1比较字符串通常,在VBA中进行字符串比较时,会用到比较运算符(如=、等)、Like运算符和StrComp函数。此外,在模块的开头用OptionCompare语句指定比较方式。2.1.1比较运算符可以采用简单的逻辑运算符进行两个字符串的比较,即(小于)、=(小于或等于)、(大于)、=(大于或等于)、=(等于)、(不等于)。此外,还可以使用Like运算符进行比较。2.1.2StrComp函数StrComp函数返回字符串比较的结果。其语法为:StrComp(string1,string2[,compare])其中,参数string1和strng2为必需的参数,可以是任何有效的字符串表达式。参数Compare为可选参数,如果该参数为Null,将发生错误。如果参数Compare设置为常数vbUseCompareOption或-1或忽略该参数,将使用OptionCompare语句设置进行比较;如果忽略该参数且没有设置OptionCompare语句,则按二进制进行比较;如果参数Compare设置为常数vbBinaryCompare或0,则用二进制进行比较;如果参数Compare设置为常数vbTextCompare或1,则按文本进行比较;如果参数Compare设置为常数vbDatabaseCompare或2,此时仅适用于MicrosoftAccess,进行基于数据库信息的比较。StrComp函数的返回值为:如果String1String2,则返回值为-1;如果String1=String2,则返回值为0;如果String1String2,则返回值为1;如果String1或String2为Null,则返回值为Null。看看下面的示例:SubtestStringCompare()DimMyStr1AsString,MyStr2AsString,MyComp1,MyComp2,MyComp3,MyComp4MyStr1=ABCDMyStr2=abcdMyComp1=StrComp(MyStr1,MyStr2,1)'返回0MyComp2=StrComp(MyStr1,MyStr2,0)'返回-1MyComp3=StrComp(MyStr1,MyStr2)'返回-1MyComp4=StrComp(MyStr2,MyStr1)'返回1MsgBoxStrComp(MyStr1,MyStr2,1)的结果为:&MyComp1MsgBoxStrComp(MyStr1,MyStr2,0)的结果为:&MyComp2MsgBoxStrComp(MyStr1,MyStr2)的结果为:&MyComp3MsgBoxStrComp(MyStr2,MyStr1)的结果为:&MyComp4EndSub示例说明:如果StrComp函数的第三个参数值为1,则以文本比较的方式进行字符串比较;如果第三个参数值为0或忽略该参数,则以二进制比较的方式进行字符串比较。注意,文本比较的方式不区分字母大小写,而二进制比较方式则区分大小写。[编程方法和技巧]完成一次简单的单一比较,如IfUCase(sString1)UCase(sString2)Then比使用StrComp函数:IfStrComp(sString1,sString2,vbTextCompare)=-1Then在性能上要提高30%,且更容易阅读和理解。2.2转换字符串2.2.1StrConv函数使用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字符串:SubtestConverseString()DimiAsLongDimx()AsBytex=StrConv(ABCDEFG,vbFromUnicode)'转换字符串。Fori=0ToUBound(x)Debug.Printx(i)NextEndSub下面的例子将句子中每个词语的首字母转换为大写:SubtestConverseString2()Debug.PrintStrConv(mybookisthisbook.,vbProperCase)EndSub程序运行后,在VBE窗口中的立即窗口中将会看到上述结果。下面的示例演示了如何把一个字符串转换为字节数组,以便使用在API函数调用中:SubTest()DimbyArray()AsByteDimsStringAsStringsString=SomestuffbyArray=StrConv(sString,vbFromUnicode)EndSubStrConv函数将下面的字符看成是字的分隔符:Null:Chr$(0)水平制表符:Chr$(9)换行符:Chr$(10)垂直制表符:Chr$(11)换页符:Chr$(12)回车符:Chr$(13)空格:Chr$(32)[编程方法和技巧]在使用API时该函数很重要,很多程序调用都要求传递给它们Unicode字符,或者赋给返回变量Unicode字符。2.2.2Str函数将数值转换成字符串,即返回代表一个数值的字符串。其语法为:Str(number)当一个数字转成字符串时,总会在前面保留一个空位来表示正负,即字符串的第一位一定是空格或正负号。如果参数number为正,返回的字符串前面包含一空格。Str函数将句点(.)作为有效的小数点。示例如下:MyString=Str(459)'返回459MyString=Str(-459.65)'返回-459.65MyString=Str(459.001)'返回459.001[编程方法和技巧]使用LTrim函数可删除Str函数在返回的字符串开头添加的前导空格。此外,CStr函数和Format函数已经取代了Str函数,CStr函数不用为正数的符号而添加前导空格,Format函数能够用来识别小数点。2.2.3CStr函数CStr将数值表达式转换成String数据类型。示例如下:MyDouble=437.324'MyDouble为Double类型MyString=CStr(MyDouble)'MyString的内容为437.324[编程方法和技巧]传递给CStr的未初始化的数字数据类型返回“0”,传递给CStr的未初始化的日期变量返回“0:00:00”。2.3创建字符串2.3.1Space函数该函数返回指定数的空格的字符串。语法为:Space(number)其中,参数number必须,为字符串中指定的空格数。如下例所示:SubCreateString1()DimMyString'返回10个空格的字符串。MyString=Space(10)'将10个空格插入两个字符串中间。MyString=Hello&Space(10)&WorldEndSub该函数可用于在调用外部DLL时建立字符串缓冲区,特别是在调用WindowAPI时。此外,使用该函数还可以使字符串在特定长度的缓冲区左对齐或右对齐。注意,如果参数number是负数,则会产生运行时错误5:“无效的过程调用或参数”。[编程方法和技巧]可以使用Space函数添加和清除存储在定长字符串中的数据,例如,下面的代码用空格填充一个定长字符串:DimstrFixedAsString*32……strFixed=Space(Len(strFixed))2.3.2String函数该函数返回重复的字符或字符串。其语法为:String(number,character)其中,参数number必须,指定所返回的字符串的长度;参数character必须,指定字符的字符代码或字符串表达式。例如,下面使用String函数生成指定长度且只含单一字符的字符串。SubCreateString2()DimMyStringMyString=String(5,*)'返回*****MyString=String(5,42)'返回*****MyString=String(10,ABC)'返回AAAAAAAAAAEndSub如果参数number包含Null,则返回Null;如果参数character包含Null,则返回Null;参数character可以指定为字符串或者是ANSI字符代码,如:strString1=String(128,”=”)‘用”=”填充strString2=String(128,0)‘用Chr$(0)填充[编程方法和技巧](1)String函数在用于创建较长的“_”,“-”,或者“=”构成的水平线以便给报表分段时十分有用。(2)当调用API函数向缓冲区写入字符串值时,首先要用String函数创建一个长度合适的字符串变量,并且用诸如Chr$(0)之类的单个字符来填充。2.4获取字符串的长度可以使用Len函数来确定任何字符串或字符串表达式的长度,其语法为:Len(string|varname)其中,参数string为任何有效的字符串表达式;参数varname为任何有效的变量名称。两个参数必须取一。利用LenB函数可以确定存储某变量所需的实际字节数。下面的示例使用Len函数来获取某字符串的长度(字符数)或某变量的大小(位数)。TypeCustomerRecord'定义用户自定义的数据类型IDAsInteger'将此定义放在常规模块中NameAsString*10AddressAsString*30EndTypeSubGetStrLen()DimCustomerAsCustomerRecord'声明变量DimMyIntAsInteger,MyCurAsCurrencyDimMyString,MyLenMyString=HelloWorld'设置变量初值MyLen=Len(MyInt)'返回2MyLen=Len(Customer)'返回42MyLen=Len(MyString)'返回11MyLen=Len(MyCur)'返回8EndSub此外,在需要大量判断是否为空字符串的代码中,使用Len函数也可以加快代码执行的速度。例如:IfstrTemp=Then'要执行的代码EndIf上面的代码可以用以下代码代替
本文标题:VBA中字符串函数
链接地址:https://www.777doc.com/doc-3395277 .html