VBA信息获取与处理:如何在多个工作表中查找某个给定值

boyanx1个月前技术教程10

《VBA信息获取与处理》教程(版权10178984)是我推出第六套教程,目前已经是第一版修订了。这套教程定位于最高级,是学完初级,中级后的教程。这部教程给大家讲解的内容有:跨应用程序信息获得、随机信息的利用、电子邮件的发送、VBA互联网数据抓取、VBA延时操作,剪贴板应用、Split函数扩展、工作表信息与其他应用交互,FSO对象的利用、工作表及文件夹信息的获取、图形信息的获取以及定制工作表信息函数等等内容。程序文件通过32位和64位两种OFFICE系统测试。是非常抽象的,更具研究的价值。

教程共两册,二十个专题。今日分享内容是:VBA信息获取与处理第四个专题第六节:如何在多个工作表中查找某个给定值

【分享成果,随喜正能量】104苦难不会没完没了,幸运也不会永远持续。得意时不忘形,失意时不消沉。人生的起伏都是考验。知幻即离,一个人最了不起的能力,不是摆平任何人,而是摆正自己。。

专题四 EXCEL工作表数据的读取、回填和查找

这个专题,我们讲解工作表数据的处理的问题,对于VBA而言,我给予的定位是“实现个人小型数据自动化处理的利器”,对于大多数朋友而言,利用VBA是与EXCEL相关联的,很多的代码也是用于处理EXCEL内或者相关的各种数据,工作表更是作为和用户的交互对象而存在,那么对于工作表的数据如何进行查找,以及如何读取就是一个十分关键的课题,我们这讲就来主要讲解这个问题。

第六节 如何在多个工作表中查找某个给定值

大家好,我们今天讲这个专题的最后一讲,如何在多个工作表中查找某个给定值,当然要求这个给定的值在一个工作表中要是单一的值,如果是多个值我们可以稍微改一下代码即可,我们不再做详细讲解。

1 在多个工作表中查找给定值要首先求出每个工作表的名称

求出每个工作表的名称,我们只需用
ThisWorkbook.Worksheets.Item(i).Name即可以完成,我们看下面的代码:

Dim WSArray()

n = ThisWorkbook.Worksheets.Count

ReDim WSArray(1 To n)

For i = 1 To n

WSArray(i) = ThisWorkbook.Worksheets.Item(i).Name

Next

代码解读:

上述代码首先建立了一个动态数组WSArray(),这个动态数组将用来存储各个工作表的名称。变量n指的是当前工作薄所有工作表的数量,取得这个数量后,我们重读这个动态数组,然后给数组赋值。

2 利用单值查找的程序完成余下的工作

当我们取得后每个工作表的名称后,我们就可以在每个工作表中进行查找,并将结果放到Cells(i, "i")单元格中,我们看下面的代码:

Sheets("Sheet7").Select

Range("i2 : I3000").ClearContents

i = 2

Do While Cells(i, "h") <> ""

UU = Cells(i, "h")

For t = 1 To n

Set FJX = Sheets(WSArray(t)).Columns("A").Find(UU, lookat:=xlWhole)

If Not FJX Is Nothing Then

Cells(i, "i") = Cells(i, "i") & " " & Sheets(WSArray(t)).Cells(FJX.Row, 2).Value

End If

Next

Set FJX = Nothing

i = i + 1

Loop

代码讲解:Cells(i, "i") = Cells(i, "i") & " " & Sheets(WSArray(t)).Cells(FJX.Row, 2).Value 这句代码中Sheets(WSArray(t))就是正在执行查找的工作表的名称。这个名称由数组的值确定,对于每个工作表都执行类似的操作后,指定单元格中就得到了最后的查询结果。另外需要注意的是我这里给出的是一个完全匹配查找,大家在实际利用的时候可以进行换成不完全匹配查找。

3 多工作表查询的总代码

最后我给出整个过程的代码:

Sub MYNZK() '多工作表,每个工作表为唯一查询

Dim WSArray()

Dim FJX As Variant

n = ThisWorkbook.Worksheets.Count

ReDim WSArray(1 To n)

For i = 1 To n

WSArray(i) = ThisWorkbook.Worksheets.Item(i).Name

Next

Sheets("Sheet7").Select

Range("i2 : I3000").ClearContents

i = 2

Do While Cells(i, "h") <> ""

UU = Cells(i, "h")

For t = 1 To n

Set FJX = Sheets(WSArray(t)).Columns("A").Find(UU, lookat:=xlWhole)

If Not FJX Is Nothing Then

Cells(i, "i") = Cells(i, "i") & " " & Sheets(WSArray(t)).Cells(FJX.Row, 2).Value

End If

Next

Set FJX = Nothing

i = i + 1

Loop

MsgBox ("OK")

End Sub

代码截图:

代码的注意点:工作表名称的利用要注意是当前正在查询工作表,被查询的数据位于Sheets("Sheet7")的H列,结果返回到I列。

由于代码比较简单,这里就不再过多的讲解了,下面看返回的结果:

最后我再给出几个问题的引申:

1)如果要查询的工作表是给定的呢?该如何处理?

2)如果每个工作表中的数据不是唯一的值,该如何处理?

本节知识点回向:如何实现多工作表中的查询?实现过程中的关键点是什么?

本专题参考程序文件:004工作表.XLSM

我20多年的VBA实践经验,全部浓缩在下面的各个教程中,教程学习顺序:


相关文章

腾讯云国际站:腾讯云怎样检测隐藏的后门程序?

本文由【云老大】 TG@yunlaoda360 撰写文件完整性验证文件 hash 校验 :可使用 md5sum 命令对文件进行哈希值计算,并与原始代码的 hash 值进行对比,从而快速发现文件是否被篡...

用Python进行机器学习(6)随机森林

上一节我们讲到了决策树这个算法,但是一棵决策树可能会存在过拟合的现象,而且对数据微小的变化也比较敏感,为了解决这些问题,我们可以通过多棵树的方式,也就是今天要介绍的随机森林。随机森林算法也就是Rand...

MyBatis批量插入的3种方案对比,速度差10倍!

你还在用for循环做MyBatis批量插入? 本文通过真实案例+代码实测,对比三种批量插入方案的速度差异与实现原理。文末附实测数据截图,看完立省80%数据库操作时间!一、青铜方案:循环单条插入(性能灾...

Go协程与Async/Await对比分析

一、并发模型的核心差异Go的协程(goroutine)基于CSP模型:通过goroutine和channel实现通信顺序进程用户态轻量线程:协程栈初始为2KB(动态扩展),上下文切换开销极小隐式异步:...

Java隐藏的10倍效率技巧!90%程序员不知道的魔法方法(附代码)

导语:“同事1小时写完的代码,你用了1天?不是技术差距,是你不懂Java的隐藏魔法!今日头条首发7个颠覆认知的编码技巧,文末送《Java性能优化秘籍》!”一、灵魂暴击:用对工具代码量少一半问题场景:“...

Java同步代码块与同步方法的那些事儿

Java同步代码块与同步方法的那些事儿同步代码块:锁住指定区域想象一下,你正在参加一场紧张的拍卖会,拍卖师手里拿着珍贵的拍品。如果多个竞拍者都想抢着喊价,场面就会变得混乱不堪。这时拍卖师会设置一些规则...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。