【EXCEL_VBA_基础知识】11 使用VBA数组

课程来源:王佩丰老师的《王佩丰学VBA视频教程》,如有侵权,请联系删除!

当循环中大量使用需多次计算表达式时,可利用数组简化并提升效率(底层逻辑:只算一次,然后结果暂存,使用时去相应位置取出!

目录

0. 效率提升示例

1. 自定义数组

2. 重定义数组(可以动态调整大小的数组)

 3. UBound与LBound


0. 效率提升示例

Sub Sum_If()

Dim i, k As Integer
Dim str As String

Dim arr()

'只计算一次Range
'比每次使用range("g" & i)快
arr = Range("g1:j200000")

'查找条件
str = Range("n5")

For i = 2 To 200000

    ' 满足即累加
    If arr(i, 1) = str Then
        k = k + arr(i, 4)
    End If
    
Next

Range("p5") = k


End Sub

1. 自定义数组

'定义一维数组并赋值
Sub test()
Dim arr(1 To 4)

arr(1) = "张三"
arr(2) = "李四"
arr(3) = "王五"
End Sub

'定义二维数组并赋值
Sub test1()
Dim arr(1 To 4, 1 To 2)

arr(1, 1) = "张三"
arr(1, 2) = 30
arr(2, 1) = "李四"
arr(2, 2) = 35
arr(3, 1) = "王五"
arr(3, 2) = 40
End Sub


'将数组中的某个值输出到单元格
Sub test3()
Dim arr(1 To 4)

arr(1) = "张三"
arr(2) = "李四"
arr(3) = "王五"

Range("b2") = arr(2)
End Sub

' 将一维数组中的所有值输出到单元格区域
' 一维数组为行存储(先行后列)
Sub test4()
Dim arr(1 To 4)

arr(1) = "张三"
arr(2) = "李四"
arr(3) = "王五"

Range("a7:d7") = arr
End Sub


'将二维数组中的所有值输出到单元格区域
Sub test5()
Dim arr(1 To 3, 1 To 2)

arr(1, 1) = "张三"
arr(1, 2) = 30
arr(2, 1) = "李四"
arr(2, 2) = 35
arr(3, 1) = "王五"
arr(3, 2) = 40

Range("a15:b17") = arr


'将区域赋值给数组


Sub test6()
Dim arr()

arr = Range("a1:a5")


End Sub

2. 重定义数组(可以动态调整大小的数组

1. 首先,不指定数组大小

2. 然后使用ReDim语句来定义数组的大小

Dim arr()
Dim j, i As Integer

j = Range("a65536").End(xlUp).Row - 1 ' 确定行数

ReDim arr(1 To j)

 3. UBound与LBound

UBound用于返回数组或集合的指定维度的最大值,即上界。它接受两个参数:数组名(arrayname)和维度(dimension)。如果省略维度参数,则默认返回第一维的上界。

UBound函数与LBound函数一起使用,可以确定数组的大小。

这个函数在处理多维数组时特别有用,可以帮助确定数组的边界,从而在循环或访问数组元素时避免越界错误

Dim A(1 To 100, 0 To 3, -3 To 4)

' 使用UBound函数可以获取每个维度的上界:

LBound(A, 1) = 1
LBound(A, 2) = 0
LBound(A, 3) = -3
UBound(A, 1) = 100
UBound(A, 2) = 3
UBound(A, 3) = 4
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: "excel-vba教程完全版.pdf"是一份非常详细的Excel VBA教程。它包含了许多实例和示例,解释了Excel VBA的基本概念和语法,以及如何使用VBA编写各种Excel宏。这份教程既适合初学者学习,也适合中级和高级用户作为快速参考手册使用。 该文档的存储位置是阿里云盘,这意味着你可以随时随地使用云盘进行访问。同样,这也意味着你可以下载该文档并将其保存到任何设备上,以便您在离线时仍然可以学习和参考。 无论你是需要学习Excel VBA来改进自己的工作,还是需要了解Excel VBA基础知识作为一个数据处理或业务分析的工作要求,这个教程都非常优秀。如果你愿意花时间学习和实践,并跟随教程完成练习,你将成为一个熟练的Excel VBA程序员,能够编写更加复杂和高效的Excel宏。所以,这个教程是非常值得推荐的。 ### 回答2: excel-vba教程完全版.pdf是一本关于Excel VBA编程的教程,涵盖了许多内容,适合想要学习Excel VBA编程的初学者以及希望深入了解的进阶者。这本教程从基础概念开始,逐步深入,涵盖了VBA开发环境、数据类型、变量、运算符、控制结构、数组、函数等多个方面的内容。 此外,本教程还详细介绍了Excel VBA中常用的对象,如Workbook对象、Worksheet对象和Range对象等,以及它们的属性和方法的使用方式。同时,本教程还介绍了经典的Excel VBA编程技巧,如错误处理、调试技巧、宏录制等,让读者能够掌握高效、优化的编程方法。 总体来说,excel-vba教程完全版.pdf是一本较为全面的Excel VBA编程教程,对于Excel VBA编程感兴趣的人来说,是一本不可多得的学习资料。而作为阿里云盘上的一个资源,其存储空间也方便了用户在任何地方都可以随时下载和阅读,为Excel VBA编程爱好者提供了便利。 ### 回答3: excel-vba教程完全版.pdf是一份非常优秀的Excel VBA教程资源,非常适合希望学习如何使用Excel VBA编程的人。这份教程详细地介绍了VBA的各种基础和高级知识,包括如何使用VBA编写宏、创建用户界面以及使用各种对象、方法和属性等等。这份教程内容丰富、结构清晰、易于理解,对于初学者而言也非常友好。 在阿里云盘上获取这份教程也非常便捷和方便。用户只需要通过阿里云盘的下载链接即可下载教程文档,并可以在自己的电脑上进行阅读和学习。阿里云盘作为一种云存储服务,具有高速稳定、容量大等特点,因此不必担心下载速度和下载文件的稳定性问题。 总之,excel-vba教程完全版.pdf是一份非常优秀的VBA教程资源,对于想学习如何使用Excel VBA进行编程的人而言是一份极佳的教程材料。而且,通过阿里云盘可以轻松地获取这份教程资源,非常方便和实用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值