ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 3631|回复: 7

[求助] 比对两个表格的数据,相同就复制到sheet3

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-8-17 00:18 | 显示全部楼层 |阅读模式
本帖最后由 天舞·紫嫣 于 2018-8-17 19:19 编辑

1、以sheet1为基准,sheet2中的FG两列如果和sheet1中AB两列的数据相符,则把该数据复制到sheet3的AB列中。              
2、号码和姓名都要匹配上~~                                                
3、然后结果数据还需要做一个剔重,在个人的范围内剔重,不涉及其他人

真正sheet1有一万左右数据
sheet2有几千个数据
需要运行速度快~~谢谢各位老师"                                       
                                       
                                       
        


比对相同数据,删除重复项.rar

27.12 KB, 下载次数: 45

头像被屏蔽

TA的精华主题

TA的得分主题

发表于 2018-8-17 09:13 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-8-17 11:16 | 显示全部楼层
朱荣兴 发表于 2018-8-17 09:13
一个数组+字典的典型案例,但是:
1、 则把该数据复制到sheet3的AB列中。              是需要复制sheet1 ...

是复制sheet2中的数据,如果sheet2中的号码和姓名和sheet1完全匹配,那么就把这个数据复制到sheet3
全部复制完成后,还需要做一下剔重,比如张三这个人匹配出100个数据,在这100个数据中,有三个相同数据,那么就把这个数据剔重。


这个模拟的数据没问题的,因为原表格涉及号码太多,不方便公布,但是是完全模拟原表格。

老师如果有空请帮我看下怎么弄,表格里有个vba,但是运行起来特别慢

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-8-17 19:19 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-8-17 20:09 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
朱荣兴 发表于 2018-8-17 09:13
一个数组+字典的典型案例,但是:
1、 则把该数据复制到sheet3的AB列中。              是需要复制sheet1 ...

创建了两个字典,但如何使用exists属性比对,有点懵了,不知道怎么写了,
请大神指点下,谢谢!
  1. Sub 比对提取()
  2.     Dim dic As Object, d As Object
  3.     Dim i As Long, j As Long, m As Long, n As Long
  4.     Dim Arr, Brr, Crr
  5.     Application.ScreenUpdating = False
  6.     m = Sheet1.Range("A65536").End(xlUp).Row
  7.     n = Sheet2.Range("F65536").End(xlUp).Row
  8.     Set dic = CreateObject("scripting.dictionary")
  9.     Set d = CreateObject("scripting.dictionary")
  10.     Arr = Sheet1.Range("A2:B" & m)
  11.     Brr = Sheet2.Range("F1:G" & n)
  12.     For i = 1 To UBound(Arr, 1)
  13.         dic(Arr(i, 1) & Arr(i, 2)) = ""
  14.     Next
  15.     For j = 1 To UBound(Brr, 1)
  16.         d(Brr(j, 1) & Brr(j, 2)) = ""
  17.     Next
  18.    
  19.     '下面比对相同项,并读取出来,有点不知道怎么写了,请大神指点下,谢谢
  20.     For j = 1 To UBound(Brr, 1)
  21.         If d.exists(dic.Key) Then
  22.         
  23.         End If
  24.     Next
  25.     Application.ScreenUpdating = True
  26. End Sub
复制代码


TA的精华主题

TA的得分主题

发表于 2018-8-17 20:33 | 显示全部楼层
写好了,请测试。
如有帮助,请送朵小花。
请测试.rar (29.4 KB, 下载次数: 223)
  1. Sub 比对提取()
  2.     Dim d As Object
  3.     Dim i As Long, j As Long, m As Long, n As Long, k As Long
  4.     Dim Arr, Brr
  5.     Application.ScreenUpdating = False
  6.     m = Sheet1.Range("A65536").End(xlUp).Row
  7.     n = Sheet2.Range("F65536").End(xlUp).Row
  8.     Set d = CreateObject("scripting.dictionary")
  9.     Arr = Sheet1.Range("A2:B" & m)
  10.     Brr = Sheet2.Range("F1:G" & n)
  11.     For j = 1 To UBound(Brr, 1)
  12.         d(Brr(j, 1) & Brr(j, 2)) = ""
  13.     Next
  14.     k = 1
  15.     For i = 1 To UBound(Arr, 1)
  16.         If d.exists(Arr(i, 1) & Arr(i, 2)) Then
  17.             Sheet3.Cells(k, "A") = Arr(i, 1)
  18.             Sheet3.Cells(k, "B") = Arr(i, 2)
  19.             k = k + 1
  20.         End If
  21.     Next
  22.     Application.ScreenUpdating = True
  23. End Sub
复制代码


评分

2

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-8-17 20:49 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
tudarong 发表于 2018-8-17 20:33
写好了,请测试。
如有帮助,请送朵小花。

太谢谢亲了~~~~这个很好用!!

TA的精华主题

TA的得分主题

发表于 2018-8-18 16:32 | 显示全部楼层
tudarong 发表于 2018-8-17 20:33
写好了,请测试。
如有帮助,请送朵小花。
  1. Option Explicit

  2. Sub 比对提取_学习字典()
  3.     Dim d As Object
  4.     Dim i As Long, j As Long, m As Long, n As Long, k As Long
  5.     Dim Arr, Brr, Crr
  6.     Application.ScreenUpdating = False
  7.     m = Sheet1.Range("A65536").End(xlUp).Row
  8.     n = Sheet2.Range("F65536").End(xlUp).Row
  9.     Set d = CreateObject("scripting.dictionary")
  10.     Arr = Sheet1.Range("A2:B" & m)
  11.     Brr = Sheet2.Range("F1:G" & n)
  12.     For j = 1 To UBound(Brr, 1)
  13.         d(Brr(j, 1) & Brr(j, 2)) = ""
  14.     Next
  15. '    k = 1
  16.     ReDim Crr(1 To UBound(Arr), 1 To UBound(Arr, 2))
  17.     For i = 1 To UBound(Arr, 1)
  18.         If d.exists(Arr(i, 1) & Arr(i, 2)) Then
  19.             k = k + 1
  20.             Crr(k, 1) = Arr(i, 1)
  21.             Crr(k, 2) = Arr(i, 2)
  22. '            k = k + 1
  23.         End If
  24.     Next
  25.     [A1].Resize(k, UBound(Arr, 2)) = Crr
  26.     Application.ScreenUpdating = True
  27. End Sub
复制代码
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-22 13:33 , Processed in 0.033024 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表