VBA编程-使用数组-福哥
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-模块/函数/VBA


VBA编程-使用数组

发表时间:2023/1/12 11:46:47 评论(0) 浏览(1791)  评论 | 加入收藏 | 复制
   
摘 要:您可以声明一个数组以处理一组相同数据类型的值。 数组是具有多个可存储值的隔离舱的单个变量,而典型的变量只有一个存储隔离舱,其中只能存储一个值。 您可以在需要引用数组中包含的所有值时将数组作为整体引用,也可以引用其中的单个元素。
正 文:

VBA编程-使用数组

您可以声明一个数组以处理一组相同数据类型的值。 数组是具有多个可存储值的隔离舱的单个变量,而典型的变量只有一个存储隔离舱,其中只能存储一个值。 您可以在需要引用数组中包含的所有值时将数组作为整体引用,也可以引用其中的单个元素。

例如,若要存储一年中每天的日常开支,您可以声明一个具有 365 个元素的数组变量,而不是声明 365 个变量。 数组中的每个元素包含一个值。 以下语句声明具有 365 个元素的数组变量。 默认情况下,数组的索引从零开始,因此该数组的上限是 364 而不是 365。

VB复制

Dim curExpense(364) As Currency 
 

若要设置单个元素的值,您可以指定该元素的索引。 以下示例向该数组中的每个元素均分配一个初始值 20。

VB复制

Sub FillArray() 
 Dim curExpense(364) As Currency 
 Dim intI As Integer 
 For intI = 0 to 364 
 curExpense(intI) = 20 
 Next 
End Sub

更改下限

使用 模块顶部的 Option Base 语句将第一个元素 的默认索引从 0 更改为 1。 在下面的示例中, Option Base 语句更改第一个元素的索引, Dim 语句声明包含 365 个元素的数组变量。

VB复制

Option Base 1 
Dim curExpense(365) As Currency 
 

也可以通过使用 To 子句明确设置数组的下限,如以下示例所示。

VB复制

Dim curExpense(1 To 365) As Currency 
Dim strWeekday(7 To 13) As String 
 

在数组中存储 Variant 值

有两种方法可以创建 Variant 值的数组 。 一种是声明 Variant 数据类型的数组,如以下示例所示:

VB复制

Dim varData(3) As Variant 
varData(0) = "Claudia Bendel" 
varData(1) = "4242 Maple Blvd" 
varData(2) = 38 
varData(3) = Format("06-09-1952", "General Date") 
 

另一种方法是将 Array 函数返回的数组分配给 Variant 变量,如以下示例所示:

VB复制

Dim varData As Variant 
varData = Array("Ron Bendel", "4242 Maple Blvd", 38, _ 
Format("06-09-1952", "General Date")) 
 

无论使用哪种方法创建数组,均可通过索引识别 Variant 值的数组中的元素。 例如,以下语句可添加到上述两个示例中的任意一个示例中。

VB复制

MsgBox "Data for " & varData(0) & " has been recorded." 
 

使用多维数组

在 Visual Basic 中,您可以声明最多包含 60 个维度的数组。 例如,以下语句声明了一个二维、5*10 的数组。

VB复制

Dim sngMulti(1 To 5, 1 To 10) As Single 
 

如果将数组看作矩阵,则第一个参数表示行,第二个参数表示列。

使用嵌套 For...处理 多维数组的下一语句。 以下过程使用 Single 值填充一个二维度组。

VB复制

Sub FillArrayMulti() 
 Dim intI As Integer, intJ As Integer 
 Dim sngMulti(1 To 5, 1 To 10) As Single 
 
 ' 用值填充数组。 
 For intI = 1 To 5 
 For intJ = 1 To 10 
 sngMulti(intI, intJ) = intI * intJ 
 Debug.Print sngMulti(intI, intJ) 
 Next intJ 
 Next intI 
End Sub

Access软件网交流QQ群(群号:198465573)
 
 相关文章
VBA二维数组的基础介绍  【杨雪  2019/5/18】
ADO记录集与二维数组互导  【AngelHis  2020/2/13】
Excel制作的《合并打散》源码示例分享,合并打散自定义数组函数学...  【欢乐小爪  2021/6/10】
Access使用数组求最大值函数;求一组数据最大值示例;分享一个得...  【欧志华  2022/10/21】
Access利用数组实现矩阵转换  【欧志华  2022/10/26】
查找数值在数组中的位置  【欧志华  2022/11/4】
VBA编程-声明数组  【福哥(QQ86053924)  2022/11/17】
常见问答
技术分类
相关资源
文章搜索
关于作者

福哥

文章分类

文章存档

友情链接