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

embedded/2024/9/24 3:48:56/

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

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

目录

0. 效率提升示例

1. 自定义数组

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

 3. UBound与LBound


0. 效率提升示例

Sub Sum_If()Dim i, k As Integer
Dim str As StringDim arr()'只计算一次Range
'比每次使用range("g" & i)快
arr = Range("g1:j200000")'查找条件
str = Range("n5")For i = 2 To 200000' 满足即累加If arr(i, 1) = str Thenk = k + arr(i, 4)End IfNextRange("p5") = kEnd 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) = 40Range("a15:b17") = arr'将区域赋值给数组Sub test6()
Dim arr()arr = Range("a1:a5")End Sub

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

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

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

Dim arr()
Dim j, i As Integerj = 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

http://www.ppmy.cn/embedded/42220.html

相关文章

网络模型-Qinq配置与应用

Qinq配置与应用 通过配置Qinq来实现利用公网提供的VLAN100使企业1互通,利用公网提供的VLAN200使企业2互通不同企业之间互相隔离。并通过在连接其它厂商设备的接口上配置修改0in0外层VLAN Tag的TPID值,来实现与其它厂商设备的互通。 一、创建VLAN #在Swi…

【内存泄漏Bug】registerReceiver Are you missing a call to unregisterReceiver()异常分析及解决

问题描述 开发一款WIFI管理APP,再wifi列表页面注册了广播监听,监听网络变化,页面是常驻内存的,跳转到其他app或者其他页面的时候,此页面存在被系统销毁的可能。 android.app.IntentReceiverLeaked: Activity com.xx.a…

qt面试经验

目录 1.qt底层原理2.connect的第五个参数3.信号槽的原理4.qt的智能指针QPointerQSharedPointerQScopedPointerQWeakPointerQSharedDataPointerQScopedArrayPointer 5.线程6.事件监听全局事件监听某一类控件的事件监听某一个控件的事件Qt的事件循环事件与信号的区别 7.设计模式单…

RustGUI学习(iced/iced_aw)之扩展小部件(二十三):如何使用sliderbar部件来创建滑动条?

前言 本专栏是学习Rust的GUI库iced的合集,将介绍iced涉及的各个小部件分别介绍,最后会汇总为一个总的程序。 iced是RustGUI中比较强大的一个,目前处于发展中(即版本可能会改变),本专栏基于版本0.12.1. 概述 这是本专栏的第二十三篇,主要讲述sliderbar滑动条部件的使用,…

2024 中青杯高校数学建模竞赛(B题)数学建模完整思路+完整代码全解全析

你是否在寻找数学建模比赛的突破点?数学建模进阶思路! 作为经验丰富的数学建模团队,我们将为你带来2024 长三角高校数学建模竞赛(A题)的全面解析。这个解决方案包不仅包括完整的代码实现,还有详尽的建模过…

15:00面试,15:08就出来了,问的问题有点变态。。。

从小厂出来,没想到在另一家公司又寄了。 到这家公司开始上班,加班是每天必不可少的,看在钱给的比较多的份上,就不太计较了。没想到8月一纸通知,所有人不准加班,加班费不仅没有了,薪资还要降40%…

简单介绍十款可以免费使用的API测试工具

API开发应该是后端开发最常见的工作,而调试和测试API是非常关键的,这篇文章简单介绍几款常用的工具以供大家参考。 SoapUI SoapUI是很老牌的工具的,在之前Webservice盛行的时候经常会用到。 现在官方推出了Pro版本的ReadyAPI,但要…

列表的创建和删除

目录 使用赋值运算符直接创建列表 创建空列表 创建数值列表 删除列表 自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501\ 对于歌曲列表大家一定很熟悉,在列表中记录着要播放的歌曲名称…