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

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

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

目录

[0. 效率提升示例](#0. 效率提升示例)

[1. 自定义数组](#1. 自定义数组)

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

[3. UBound与LBound](#3. UBound与LBound)


0. 效率提升示例

vbnet 复制代码
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. 自定义数组

vbnet 复制代码
'定义一维数组并赋值
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语句来定义数组的大小

vbnet 复制代码
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函数一起使用,可以确定数组的大小。

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

vbnet 复制代码
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
相关推荐
啊哈哈哈哈啊有2 小时前
导出树形结构,excel
java·windows·excel
Dxy12393102167 小时前
Elasticsearch 聚合入门:像 Excel 透视表一样分析数据
elasticsearch·excel
一位代码7 小时前
Excel | .xls 与 .xlsx 文件的区别及使用 Excel 打开 CSV 文件出现乱码的解决办法
excel
CodeCraft Studio8 小时前
Excel处理控件Aspose.Cells教程:使用C#在Excel中创建树状图
前端·c#·excel·aspose·c# excel库·excel树状图·excel sdk
悟能不能悟9 小时前
vue导出excel文件
前端·vue.js·excel
CodeCraft Studio9 小时前
国产化Excel开发组件Spire.XLS教程:以Python编程方式在Excel中高亮重复值
开发语言·python·excel·spire.xls·excel自动化·excel高亮重复值·python处理excel
喝汽水的猫^1 天前
Java实现Excel 导出(多 Sheet、复杂格式)
java·excel
小费的部落1 天前
Excel 在Sheet3中 匹配Sheet1的A列和Sheet2的A列并处理空内容
java·前端·excel
缺点内向1 天前
如何在 C# 中重命名 Excel 工作表并设置标签颜色
开发语言·c#·excel
wtsolutions1 天前
Sheet-to-Doc: Automate Document Generation with Excel Data and Word Templates
word·excel·wtsolutions