Excel常用技能分享与探讨(5-宏与VBA简介之VBA的数组与集合)
myzbx 2025-07-01 22:13 3 浏览
总结
数组:适合处理固定大小、类型一致、需要快速访问的数据。
集合:适合动态增删、键值查找或混合类型数据。
根据具体需求选择合适的数据结构,可显著提升代码效率和可读性。
一、从仓库管理理解数据结构(场景化入门)
储物间模型:
- 数组 → 固定尺寸的储物柜(每个格子有固定编号)
- 集合 → 可伸缩的收纳箱(随意增减物品)
- 字典 → 带标签的储物盒(通过钥匙编号快速查找)
二、数组
2.1 基础操作
2.1.1.基本概念
- 数组是一组有序元素的集合,所有元素类型相同。
- 通过索引(从0或1开始)访问元素。
- 分为静态数组(固定大小)和动态数组(大小可变)。
2.1.2.声明与初始化
' 静态数组
Dim arrStatic(1 To 5) As Integer ' 索引1到5
Dim arrStatic2(0 To 4) As String ' 索引0到4
' 动态数组
Dim arrDynamic() As Variant
ReDim arrDynamic(1 To 3) ' 初始化大小
ReDim Preserve arrDynamic(1 To 5) ' 保留原有数据并扩展大小
2.1.3.常用操作
- 赋值与访问:
arrStatic(1) = 10
MsgBox arrStatic(1)
- 遍历数组:
For i = LBound(arr) To UBound(arr)
Debug.Print arr(i) Next i
- 多维数组:
Dim matrix(1 To 3, 1 To 3) As Integer
matrix(2, 2) = 5
' ① 声明数组
Dim 成绩单(1 To 50) As Integer ' 创建50个格子
' ② 填充数据
For i = 1 To 50
成绩单(i) = Cells(i + 1, 2).Value
Next
' ③ 批量处理
For i = 1 To UBound(成绩单)
成绩单(i) = 成绩单(i) + 5 ' 每人加5分
Next
' ④ 写回表格
Range("C2:C51").Value = Application.Transpose(成绩单)
- 动态数组:
Dim 动态数组() As Variant
' 自动匹配数据区域
动态数组 = Range("A1").CurrentRegion.Value
' 扩展数组
ReDim Preserve 动态数组(1 To 100, 1 To 5)
2.2.优点与缺点
- 优点:
- 访问速度快(连续内存)。
- 适合存储固定数量或类型一致的数据。
- 缺点:
- 大小固定(静态数组)或调整麻烦(动态数组需用 ReDim Preserve)。
- 无法直接删除元素。
三、集合
3.1 基础操作
3.1.1.基本概念
- 集合是动态数据结构,可存储不同类型元素。
- 元素通过键(Key)或索引访问(索引从1开始)。
- 属于VBA内置对象,需先创建实例。
3.1.2.创建与基本操作
Dim coll As New Collection ' 创建集合
' 添加元素(可指定键)
coll.Add "Apple", "Key1" ' 元素值, 键(可选)
coll.Add 123
coll.Add Range("A1")
' 访问元素
MsgBox coll(1) ' 通过索引(从1开始)
MsgBox coll("Key1") ' 通过键
' 删除元素
coll.Remove 1 ' 删除索引为1的元素
coll.Remove "Key1" ' 删除键为Key1的元素
' 遍历集合
Dim item As Variant
For Each item In coll
Debug.Print item
Next item
3.1.3.常用属性和方法
- Count:返回集合元素数量。
Debug.Print coll.Count
- Exists函数(需自定义):
Function IsKeyExists(coll As Collection, key As String) As Boolean
On Error Resume Next
IsKeyExists = Not IsEmpty(coll(key))
On Error GoTo 0
End Function
3.2 典型应用场景
- 去除重复值(比Excel去重更快)
- 动态记录用户操作日志
- 管理不规则数据组
3.3 优点与缺点
- 优点:
- 动态增删元素。
- 支持键值对,查找方便。
- 可存储混合类型数据。
- 缺点:
- 访问速度慢于数组。
- 无法直接排序或批量操作。
四、数组 vs 集合:选择你的工具
特性 | 数组 | 集合 |
存储效率 | 内存连续,速度快 | 动态分配,稍慢 |
大小调整 | 需ReDim Preserve | 自由增删 |
查找速度 | 遍历查找 | 通过Key快速定位 |
适用场景 | 数值计算/矩阵运算 | 动态数据管理/去重 |
内存占用 | 固定 | 随内容变化 |
五、五大实战案例
1.使用数组
' 快速处理单元格区域数据
Dim dataRange As Variant
dataRange = Range("A1:C10").Value ' 读取到二维数组
For i = 1 To UBound(dataRange, 1)
For j = 1 To UBound(dataRange, 2)
dataRange(i, j) = dataRange(i, j) * 2
Next j
Next i
Range("A1:C10").Value = dataRange
2.使用集合
' 管理动态项目列表
Dim tasks As New Collection
tasks.Add "Write code", "Task1"
tasks.Add "Test module", "Task2"
If IsKeyExists(tasks, "Task1") Then
tasks.Remove "Task1"
End If
3.数组与集合的转换:
' 集合转数组
Dim arr() As Variant
ReDim arr(1 To coll.Count)
For i = 1 To coll.Count
arr(i) = coll(i)
Next i
4.筛选数组元素:
' 使用Filter函数(仅适用于一维数组)
Dim names() As String
names = Split("John,Mary,Paul", ",")
Dim result() As
String result = Filter(names, "J") ' 返回包含"J"的元素
案例1:数据清洗
Dim 数据池 As Variant
数据池 = Range("A1:G10000").Value ' 1秒读取万行数据
For i = 1 To UBound(数据池, 1)
' 删除特殊字符
数据池(i, 2) = Replace(数据池(i, 2), "#", "")
' 统一日期格式
If IsDate(数据池(i, 3)) Then
数据池(i, 3) = Format(数据池(i, 3), "yyyy-mm-dd")
End If
Next
Range("A1:G10000").Value = 数据池 ' 1秒写回
案例2:多表合并去重
Dim 总表 As New Collection
On Error Resume Next ' 忽略重复报错
For Each ws In Worksheets
For Each cell In ws.Range("A2:A1000")
If cell <> "" Then 总表.Add cell.Value, CStr(cell.Value)
Next
Next
' 导出唯一值
Range("H2").Resize(总表.Count).Value = Application.Transpose(总表)
六、避坑指南
6.1 常见错误表
错误现象 | 原因分析 | 解决方案 |
"下标越界"(Error 9) | 访问不存在的数组索引 | 检查UBound/LBound |
"类型不匹配"(Error 13) | 数组元素类型不一致 | 声明时指定明确类型 |
集合Key重复 | 重复添加相同Key | 添加前检查Exists属性 |
动态数组未初始化 | 使用前未ReDim | 先ReDim再赋值 |
6.2 安全操作规范
' 数组越界防护
If i <= UBound(数据数组) Then
' 安全操作代码
End If
' 集合存在性检查
Function 包含Key(集合 As Collection, Key As String) As Boolean
On Error Resume Next
包含Key = Not IsEmpty(集合(Key))
On Error GoTo 0
End Function
七、调试实验室
7.1 立即窗口查看数组
' 输入查看命令
?Join(数据数组, ",") ' 显示一维数组所有元素
?数据池(2,3) ' 查看第二行第三列元素
7.2 可视化监视技巧
在VBA编辑器中:
- 运行→添加监视
- 输入变量名:数据池
- 展开查看多维元素
下章预告:《函数与过程》
相关推荐
- 判断变量是否为数组(判断变量是否为数组的函数)
-
大家好,我是前端西瓜哥,今天带大家学习在JS中如何判断一个对象是否为数组。Array.isArray最好的写法是使用Array.isArray(val)。因为该方法能正确判断iframe传过...
- 2023-03-13:给定一个整数数组 A,坡是元组 (i, j),其中 i < j 且 A[i]
-
2023-03-13:给定一个整数数组A,坡是元组(i,j),其中i<j且A[i]<=A[j],这样的坡的宽度为j-i。找出A中的坡的最大宽度,如果不存在,返...
- 世界上形形色色的“奇葩”小望远镜②
-
上一篇我们介绍了在探索伽玛射线暴、超新星上大放光彩的小望远镜,但天文学所研究的领域却是非常的多,比如我们所好奇的暗物质以及太阳系外行星等,那么在这些方面做出突出贡献的“奇葩”小望远镜都是谁呢?1、蜻蜓...
- C#解析多层嵌套的JSON数组(多层嵌套json转换成map)
-
首先引用开源类库:Newtonsoft.Json.dll,目前最低支持.NET3.5版本。官方帮助文档:http://www.newtonsoft.com/json/help/html/Samples...
- Vlookup函数的这7个应用技巧都不掌握,那就真的Out了
-
查询引用,用到最多的函数为Vlookup,但你真的会用吗?其实,Vlookup函数除了常规的查询引用外,还有多种使用技巧一、Vlookup函数:功能及语法结构。功能:在指定的数据范围内返回符合查询要...
- C语言-闲聊一维、二维数组(c语言中二维数组的定义和使用)
-
①若a[i]为一维数组则有,a[0],为数组的一个元素。a[i]=*(&a[i]),为数组的一个元素。a+i=&a[i],为元素a[i]的地址。*(*(a+i))=*(*&a[...
- Excel常用技能分享与探讨(5-宏与VBA简介之VBA的数组与集合)
-
总结数组:适合处理固定大小、类型一致、需要快速访问的数据。集合:适合动态增删、键值查找或混合类型数据。根据具体需求选择合适的数据结构,可显著提升代码效率和可读性。一、从仓库管理理解数据结构(场景化入门...
- 数据结构串和数组(一)(数据结构串的概念)
-
一、串的基本概念串是由零个或多个字符组成的有限序列。记作str="a0a1…an-1"(n≥0)。串中所包含的字符个数n称为串长度,当n=0时,称为空串。一个串中任意连续的字符组成的子...
- C语言进阶教程:指针数组与数组指针
-
在C语言中,指针和数组是两个核心且紧密相关的概念。当它们结合时,就产生了指针数组(ArrayofPointers)和数组指针(PointertoanArray)。这两者在语法、含义和用途上都...
- 一篇文章搞懂数组的所有知识点(一篇文章搞懂数组的所有知识点怎么写)
-
1.一维数组数组是一种数据结构,用来存储多个相同类型的数据,并通过索引来访问每个元素。概念描述示例代码什么是数组?数组是一种数据结构,用来存储一组相同类型的值。你可以把它想象成一个排好序的储物柜,每...
- 这些Java基础知识,诸佬们都还记得嘛(学习,复习,面试均可)
-
方法重载和方法重写的区别方法重写重写体现在继承关系上。在Java中,子类继承父类,子类就会具备父类所以的特征,以及父类的方法和变量比如动物类有“叫”的方法,小狗小猫分别继承了动物类,重写方法时就可以...
- js将list转化为tree格式的几种写法
-
最近在考虑一个树状结构存储。最终需要将list转化为tree格式源数据示例源数据共401条[{"menuId":"5f50c5fb8f0d74536bbfb7a4"...
- Java学习之数组——java基础篇(java数组知识)
-
如果希望保存一组有相同类型的数据,可以使用数组。数组的定义和内存分配Java中定义数组的语法有两种:typearrayName[];type[]arrayName;type为Java中的任...
- C语言-数组平均值与排序(c语言数组平均数)
-
①目标输入一个正数数组,求平均值,并根据平均值重新排序,大于平均值的数前置,小于等于平均值的值后置。~②命令行#include<stdio.h>调用输入输出函数库#include<...
- 数据结构串和数组(二)(数据结构串的概念)
-
数组的基本概念数组是一个二元组(idx,value)的集合,对每个idx,都有一个value值与之对应。idx称为下标,可以由一个整数、两个整数或多个整数构成,下标含有d(d≥1)个整数称为维数是d。...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)