VBA数组入门_第1页
VBA数组入门_第2页
VBA数组入门_第3页
VBA数组入门_第4页
VBA数组入门_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

VBA 数组入门一、初识数组1、数组就是一个列表或一组数据表。我们学习数组的目的,就是为了加速我们代码的效率。2、我们如何运用数组呢?首先,必须声明数组。其次,给数组赋值,可以是经过一系列的运算后再赋值给数组。最后,将数组返回到工作表区域中。最终的目的是在工作表中显示我们想要的结果。3、调试数组的手段:本地窗口我们可以通过设置 Stop 语句,或 F8 逐步执行代码,在本地窗口中观测数组的变化。Sub test()Dim arrSheetName(5) As StringStopEnd Sub4、数组的优势与不足数组的速度优势是明显的,但不足也很明显,因为,数组处理的都是数据,因此,它不能给 EXCEL数据添加颜色,删除行列,插入行列等等动作。5、VBA 数组没有内存数组和一般数组之分。我们在声明数组时,就已经将数组写入内存里。二、声明数组1、声明一个数组变量,也是用 Dim 语句来声明。当声明了一个数组,便决定了这个数组用于存储数据所用的内存空间。Dim arrCnt(10) As IntegerDim arrSheetName(5) As StringDim arr(7) As Variant1) 、这里我们看到,与一般定义不同的是多了个带括号的数字。这个数字,就是这个数组所能存储的最大元素数。2) 、数组可以根据我们的需要存储不同类型的数据,这与我们平常变量定义的类型一样,可以是Integer,Long,String,Variant 等等。2、注意,上面定义数组的例子是静态数组,所以,我们在声明数组时,就决定了数组用于存储数据所用的内存空间大小。后面我们会讲到动态数组。三、数组的上界和下界1、VBA 中,数组默认的下界是 0,也就是 Option Base 0如果,我们习惯了用 1 作为我们的下界,可以强制声明:Option Base 1注:Option Base 0(1)必须放在所有模块之前。2、当然,我们也可以忽略这个强制声明,那我们就需要在声明数组时,指明数组的上界和下界,如:Dim arrSheetName(1 to 3) as String表明这个数组的上下界分别是 1 和 3。四、静态数组和动态数组我们之前所定义的数组,都是静态数组。静态数组的特点是具有大小的数组。当我们事先知道数组的大小,那么,我们可以直接声明为静态数组。如果我们不知道数组大小,那么我们应定义成动态数组。1、动态数组是可以改变大小的数组,通过在数组名称后附带空括号来声明,如:Dim arrSheetName() as String2、在定义动态数组之后,必须使用 ReDim 来设置动态数组的上界和下界,为数组重新分配存储空间。3、我们可以使用 ReDim 语句反复地改变数组的元素已经维数。Sub arr1()Dim arr() As LongDim i As LongReDim arr(1 To 3)For i = 1 To 3arr(i) = iNextSheet1.a1.Resize(1, 3) = arrStopReDim arr(1 To 10)For i = 1 To 10arr(i) = iNextSheet1.a1.Resize(1, 10) = arrEnd Sub4、ReDim Preserve 语句Preserve 英文的意思是保留,保存。顾名思义,就是重新定义数组时,将数组元素保留在数组中。与 ReDim 不同的是,使用了 ReDim Preserve,只能通过改变上界,即最末维的大小,来改变数组的大小,且不能改变数组维数。如果改变了下界,就会出现错误信息。例子,见后面的过程 Join2。五、一维数组和多维数组我们前面所举的例子都是一维数组,数组可以定义多达 60 维。但我们很少看到多过 2 维的代码。这也是因为对于 Excel 的工作表来说,行和列,就是表示 2 维,我们处理的数据区域很多都是围绕行和列进行处理。因此,我们只要掌握的二维数组,就掌握了对Excel 的数据处理。下面通过 2 幅图来理解二维数组:1、定义一个二维数组Dim arrSource(1 to 100, 1 to 10) As Long2、定义一个三维数组Dim arrSource(1 To 10, 1 To 6, -1 To 5) As Long注:我们可以通过节点的多少来判断数组维数。六、数组函数1、Array 函数返回一个包含数组的 Variant。Array 函数在运行代码执行期间创建数组,而不必事先知道数组的大小。Sub Array1()Dim arr As Variantarr = Array(1, 2, 3)MsgBox arr(0)End Sub2、Lbound、Ubound 函数LBound 函数:返回一个 Long 型数据,其值为指定的数组维可用的最小下标。UBound 函数:返回一个 Long 型数据,其值为指定的数组维可用的最大下标。Sub ULbound1()Dim arr As Variantarr = Array(1, 2, 3)MsgBox UBound(arr)MsgBox LBound(arr)End SubSub ULbound2()Dim arr(1 To 100, 1 To 10, -1 To 3) As IntegerMsgBox UBound(arr, 1)MsgBox UBound(arr, 2)MsgBox LBound(arr, 3)End Sub3、Split 函数返回一个下标从零开始的一维数组,它包含指定数目的子字符串。语法:Split(expression, delimiter, limit, compare)expression 必需的。包含子字符串和分隔符的字符串表达式 。如果expression 是一个长度为零的字符串(“),Split 则返回一个空数组,即没有元素和数据的数组。delimiter 可选的。用于标识子字符串边界的字符串字符。如果忽略,则使用空格字符(“ “)作为分隔符。如果 delimiter 是一个长度为零的字符串,则返回的数组仅包含一个元素,即完整的 expression 字符串。limit 可选的。要返回的子字符串数,1 表示返回所有的子字符串。compare 可选的。数字值,表示判别子字符串时使用的比较方式。关于其值,请参阅“设置值”部分。Sub Split1()Dim strJoin As StringDim arrSplit As VariantstrJoin = “a,b,c“arrSplit = Split(strJoin, “,“)Sheet1.a1.Resize(1, 3) = arrSplitEnd Sub4、Join 函数返回一个字符串,该字符串是通过连接某个数组中的多个子字符串而创建的。语法:Join(sourcearray, delimiter)sourcearray 必需的。包含被连接子字符串的一维数组。delimiter 可选的。在返回字符串中用于分隔子字符串的字符。如果忽略该项,则使用空格(“ “)来分隔子字符串。如果 delimiter 是零长度字符串(“),则列表中的所有项目都连接在一起,中间没有分隔符。Sub Join1()Dim strJoin As StringstrJoin = Join(Array(“a“, “b“, “c“), “,“)MsgBox strJoinEnd Sub5、Filter 函数返回一个下标从零开始的数组,该数组包含基于指定筛选条件的一个字符串数组的子集。语法:Filter(sourcesrray, match, include, compare)sourcearray 必需的。要执行搜索的一维字符串数组。match 必需的。要搜索的字符串。include 可选的。Boolean 值,表示返回子串包含还是不包含 match 字符串。如果 include 是 True,Filter 返回的是包含 match 子字符串的数组子集。如果 include 是 False,Filter 返回的是不包含 match子字符串的数组子集。compare 可选的。数字值,表示所使用的字符串比较类型。有关其设置,请参阅下面的“设置值”部分。查找 2 数组的差集Sub Filter1()Dim varArr1 As VariantDim varArr2 As VariantDim i As IntegervarArr2 = Array(1021, 1023, 1025)varArr1 = Array(1021, 1022, 1023, 1024, 1025, 1026, 1027, 1028)For i = 0 To UBound(varArr2)varArr1 = VBA.Filter(varArr1, varArr2(i), False)Next iMsgBox Join(varArr1)End Sub注意,filter 函数在此是模糊查找,下面代码将无法返回我们想要的值Sub Filter1()Dim varArr1 As VariantDim varArr2 As VariantDim i As IntegervarArr2 = Array(10, 1023, 1025)varArr1 = Array(1021, 1022, 1023, 1024, 1025, 1026, 1027, 1028)For i = 0 To UBound(varArr2)varArr1 = VBA.Filter(varArr1, varArr2(i), False)Next iMsgBox Join(varArr1)End Sub七、释放数组在某些情况下,我们根据需要来释放数组来重新定义数组,或避免数据堆栈。Erase 语句重新初始化大小固定的数组元素,以及释放动态数组的存储空间。即,Erase 可以删除静态数组和动态数组里的数据元素。Sub Erase1()Dim arr(1 To 100) As Integerarr(1) = 1MsgBox arr(1)MsgBox UBound(arr)Erase arrMsgBox arr(1)MsgBox UBound(arr)End Sub从上面的代码中,我们可以看到,Erase 语句用于清除数组元素,对静态数组维数和上标是没有改变的。而对于动态数组,Erase 语句在释放动态数组所使用的内存后。在下次引用该动态数组之前,程序必须使用 ReDim 语句来重新定义该数组变量的维数。Sub Erase2()Dim arr() As IntegerReDim arr(1 To 100)arr(1) = 1MsgBox arr(1)MsgBox UBound(arr)Erase arrReDim arr(1 To 10)MsgBox arr(1)MsgBox UBound(arr)End Sub八、数组与单元格区域通过上面的几个概念,我们明白了数组的定义、

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论