使用VBA快速比对数据

实例需求:第一行是全系列数据集合,现在需要对比第一行数据,查找第2行数据中缺失的数字,保存在第3行中。

具备VBA初步使用经验的同学,都可以使用双重循环实现这个需求,这里给大家提供另一种实现思路,如何快速找到这些缺失数字。

复制代码
Sub Demo()
    Dim res(), arrData1, arrData2
    Dim sNumlist, iCnt, iIdx, i
    arrData1 = Range([B1], [B1].End(xlToRight))
    arrData2 = Application.Transpose(Application.Transpose(Range([A2], [B2].End(xlToRight).Offset(0, 1))))
    sNumlist = Join(arrData2, "|")
    iCnt = UBound(arrData1, 2)
    ReDim res(0, 1 To iCnt)
    iIdx = 1
    For i = 1 To iCnt
        If InStr(1, sNumlist, "|" & arrData1(1, i) & "|", vbTextCompare) = 0 Then
            res(0, iIdx) = arrData1(1, i)
            iIdx = iIdx + 1
        End If
    Next
    [B3].Resize(1, iCnt).Value = res
End Sub

【代码解析】

第4行代码将工作表中第1行数据加载到数组中。

第5行代码将工作表中第2行数据加载到数组中,请注意与第4行的不同之处在于,数据区域从A列到最后一个数据(J列)之后一列(K列)结束,也就是数组中的第一个和最后一个元素都是空值。经过两次Transpose,使得结果为单维数组,便于后续代码进行合并。

第6行代码调用Join函数将数组arrData2合并为一个字符串,使用竖线作为分隔符,本示例中结果如下,由于第5代码中的特殊处理,使得此处获得了起始处和结尾处的竖线,而不需要使用字符串合并单独处理。

|7|8|9|10|1|2|14|15|6|

第7行代码获取数据的个数。

第8行代码创建动态数据保存结果。

第10~15行代码使用For循环结构查找数据。

第11行代码调用Instr查找对比数据,这里的小技巧在于:如何避免将数组14或者15中的十位数字匹配数字1。在被查找数字两侧增加竖线,也就是查找|1|,这就有效的避免了上述误判,并且不需要循环遍历数组进行逐个对比。

第12行代码将缺失数字保存在结果数组中。

第13行代码保存位置序号加一。

第16行代码将结果写入到工作表中。

相关推荐
咬_咬6 小时前
go语言学习(数组与切片)
开发语言·学习·golang·数组·切片
汀、人工智能9 小时前
[特殊字符] 第106课:旋转图像
数据结构·算法·矩阵·数据库架构·数组·旋转图像
Q741_14710 小时前
每日一题 3740. 三个相等元素之间的最小距离 I 3741. 三个相等元素之间的最小距离 II 模拟 哈希表 C++ 题解
c++·算法·leetcode·模拟·数组·哈希表
wsoz1 天前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组
汀、人工智能2 天前
[特殊字符] 第78课:乘积最大子数组
数据结构·算法·数据库架构·数组·前缀积·乘积最大子数组
圣光SG4 天前
数据结构通用笔记(语言无关)
数据结构·学习·链表·数组··队列
汀、人工智能5 天前
[特殊字符] 第105课:除自身以外数组的乘积
数据结构·算法·数据库架构·数组·前缀积·除自身以外数组的乘积
Byte不洛10 天前
LeetCode中经典双指针题(环形链表 + 快乐数 + 移动零)
算法·leetcode·链表·数组·双指针
Q741_14711 天前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
烛衔溟12 天前
TypeScript 基础类型(下):数组、元组与枚举
typescript·前端开发·枚举·数组·元组