Excel 宏录制与VBA编程 —— 8、一维、二维、动态数组

该文展示了如何在VBScript中处理不同类型的数组,包括固定长度的一维数组、二维数组以及动态长度数组。通过示例代码,解释了如何初始化、赋值及安全地遍历这些数组,特别强调了使用LBound和UBound函数避免越界风险的重要性。
摘要由CSDN通过智能技术生成
一维数组
' 固定长度一维数组
Sub Array1_Sub()

    ' 定义一维数组
    Dim TestArray(1 To 4) As Integer, Num As Integer
    TestArray(1) = 101
    TestArray(2) = 102
    TestArray(3) = 103
    TestArray(4) = 104
    
    ' 指定长度遍历。缺点:有输入错误越界风险
    For Num = 1 To 4
        MsgBox "(1)Num值:" & Num & " 对应数组索引值:" & TestArray(Num)
        Next Num

    ' 自动使用最大最小长度遍历
    For Num = LBound(TestArray) To UBound(TestArray)
        MsgBox "(2)Num值:" & Num & " 对应数组索引值:" & TestArray(Num)
        Next Num

End Sub

在这里插入图片描述

二维数组
' 固定长度二维数组
Sub Array2_Sub()

    Dim TestArray(1 To 2, 1 To 4) As Integer, Row As Integer, Col As Integer
    TestArray(1, 1) = 11
    TestArray(1, 2) = 12
    TestArray(1, 3) = 13
    TestArray(1, 4) = 14
    TestArray(2, 1) = 21
    TestArray(2, 2) = 22
    TestArray(2, 3) = 23
    TestArray(2, 4) = 24
    
    ' 指定长度遍历。缺点:有输入错误越界风险
    For Row = 1 To 2
        For Col = 1 To 4
            MsgBox "行:" & Row & " 列:" & Col & " 值:" & TestArray(Row, Col)
            Next Col
        Next Row
        
    ' 自动使用最大最小长度遍历
    For Row = LBound(TestArray, 1) To UBound(TestArray, 1)
        For Col = LBound(TestArray, 2) To UBound(TestArray, 2)
            MsgBox "行:" & Row & " 列:" & Col & " 值:" & TestArray(Row, Col)
            Next Col
        Next Row

End Sub

在这里插入图片描述

动态长度数组
' 动态长度数组
Sub ArrayDynamic_Sub()

    ' 定义一维动态数组
    Dim TestArray() As Integer, Num As Integer
    
    ' 设置一维动态数组大小
    ReDim TestArray(1 To 4)
    TestArray(1) = 101
    TestArray(2) = 102
    TestArray(3) = 103
    TestArray(4) = 104
    
    ' 自动使用最大最小长度遍历
    For Num = LBound(TestArray) To UBound(TestArray)
        MsgBox "Num值:" & Num & " 对应数组索引值:" & TestArray(Num)
        Next Num
    
    ' 设置一维动态数组大小(不保留之前的数据)
    'ReDim TestArray(1 To 3)
    
    ' 设置一维动态数组大小(保留之前的数据)
    ReDim Preserve TestArray(1 To 5)
    TestArray(5) = 105
    
    ' 自动使用最大最小长度遍历
    For Num = LBound(TestArray) To UBound(TestArray)
        MsgBox "New Num值:" & Num & " 对应数组索引值:" & TestArray(Num)
        Next Num

End Sub

在这里插入图片描述

关注

笔者 - jxd

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

信必诺

嗨,支持下哥们呗。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值