ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 请教一个两表对比问题。。。。。

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-8-5 14:19 | 显示全部楼层 |阅读模式
请教一个两表对比问题。。。。。

两表比对问题.rar

3.49 KB, 下载次数: 74

TA的精华主题

TA的得分主题

发表于 2014-8-5 14:38 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-5 14:42 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
最美夕阳红 发表于 2014-8-5 14:38
没明白老师的意思

姓名 学号  金额 如两表中都有且一样,则把两表中的该行都删除,留下不一样的。。。。。

TA的精华主题

TA的得分主题

发表于 2014-8-5 14:47 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
先排序,再对比?

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-5 16:44 | 显示全部楼层
魂断蓝桥 发表于 2014-8-5 14:47
先排序,再对比?

最好不要改变顺序。。。。

TA的精华主题

TA的得分主题

发表于 2014-8-5 17:48 | 显示全部楼层
jiminyanyan 发表于 2014-8-5 16:44
最好不要改变顺序。。。。
  1. Sub yy()
  2.   Sheet1.Activate
  3.   Dim dx, dy, arr, brr, x, y, s, t, i&, j&, m&, n&
  4.   Set dx = CreateObject("Scripting.Dictionary")
  5.   Set dy = CreateObject("Scripting.Dictionary")
  6.   arr = Range("a4:c" & [a65536].End(3).Row).Value
  7.   brr = Range("e4:g" & [e65536].End(3).Row).Value
  8.   For i = 1 To UBound(arr)
  9.     t = Application.Index(arr, i, 0)
  10.     s = Join(t, ",")
  11.     dx(s) = dx(s) + 1
  12.   Next
  13.   For i = 1 To UBound(brr)
  14.     t = Application.Index(brr, i, 0)
  15.     s = Join(t, ",")
  16.     dx(s) = dx(s) - 1
  17.     dy(s) = dy(s) + 1
  18.   Next
  19.   For i = 1 To UBound(arr)
  20.     t = Application.Index(arr, i, 0)
  21.     s = Join(t, ",")
  22.     dy(s) = dy(s) - 1
  23.   Next
  24.   For Each x In dx.keys
  25.     If dx(x) < 1 Then
  26.       dx.Remove (x)
  27.     Else
  28.       For j = 1 To dx(x)
  29.          m = m + 1
  30.          arr(m, 1) = Split(x, ",")(0)
  31.          arr(m, 2) = Split(x, ",")(1)
  32.          arr(m, 3) = Split(x, ",")(2)
  33.       Next
  34.     End If
  35.   Next
  36.   For Each y In dy.keys
  37.     If dy(y) < 1 Then
  38.       dy.Remove (y)
  39.     Else
  40.       For j = 1 To dy(y)
  41.          n = n + 1
  42.          brr(n, 1) = Split(y, ",")(0)
  43.          brr(n, 2) = Split(y, ",")(1)
  44.          brr(n, 3) = Split(y, ",")(2)
  45.       Next
  46.     End If
  47.   Next
  48.   If m > 0 Then [i6].Resize(m, 3) = arr
  49.   If n > 0 Then [m6].Resize(n, 3) = brr
  50.   Set dx = Nothing
  51.   Set dy = Nothing
  52. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-8-5 17:49 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
测试附件            

140805-两表比对问题.zip

14.08 KB, 下载次数: 175

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-8-5 19:00 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-5 20:39 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 jiminyanyan 于 2014-8-5 21:16 编辑

我也写了一个,供参考。。。。。
  1. Sub yy1()
  2.   Sheet1.Activate
  3.   Dim arr1, brr1
  4.   Dim dx, dy, arr(1 To 1000, 1 To 4), brr(1 To 1000, 1 To 4), crr(1 To 1000, 1 To 3), drr(1 To 1000, 1 To 3), x, y, s, t, i&, j&, m&, n&
  5.   Set dx = CreateObject("Scripting.Dictionary")
  6.   Set dy = CreateObject("Scripting.Dictionary")
  7.   arr1 = Range("a4:c" & [a65536].End(3).Row).Value
  8.   brr1 = Range("e4:g" & [e65536].End(3).Row).Value
  9.   For i = 1 To UBound(arr1)
  10.     arr(i, 1) = arr1(i, 1)
  11.     arr(i, 2) = arr1(i, 2)
  12.     arr(i, 3) = arr1(i, 3)
  13.   Next
  14.    For i = 1 To UBound(brr1)
  15.     brr(i, 1) = brr1(i, 1)
  16.     brr(i, 2) = brr1(i, 2)
  17.     brr(i, 3) = brr1(i, 3)
  18.   Next
  19.   For i = 1 To UBound(arr)
  20.     dx(arr(i, 1)) = dx(arr(i, 1)) + 1
  21.     arr(i, 4) = dx(arr(i, 1))
  22.     s = arr(i, 1) & arr(i, 2) & arr(i, 3) & arr(i, 4)
  23.     dx(s) = ""
  24.   Next
  25.   For i = 1 To UBound(brr)
  26.     dy(brr(i, 1)) = dy(brr(i, 1)) + 1
  27.     brr(i, 4) = dy(brr(i, 1))
  28.     s = brr(i, 1) & brr(i, 2) & brr(i, 3) & brr(i, 4)
  29.     dy(s) = ""
  30.   Next
  31.   For i = 1 To UBound(arr)
  32.     s = arr(i, 1) & arr(i, 2) & arr(i, 3) & arr(i, 4)
  33.     If dy.exists(s) Then
  34.     Else
  35.         n = n + 1
  36.         crr(n, 1) = arr(i, 1)
  37.         crr(n, 2) = arr(i, 2)
  38.         crr(n, 3) = arr(i, 3)
  39.     End If
  40.   Next
  41.   For i = 1 To UBound(brr)
  42.     s = brr(i, 1) & brr(i, 2) & brr(i, 3) & brr(i, 4)
  43.     If dx.exists(s) Then
  44.     Else
  45.         m = m + 1
  46.         drr(m, 1) = brr(i, 1)
  47.         drr(m, 2) = brr(i, 2)
  48.         drr(m, 3) = brr(i, 3)
  49.     End If
  50.   Next
  51.   If m > 0 Then [i6].Resize(m, 3) = crr
  52.   If n > 0 Then [m6].Resize(n, 3) = drr
  53.   Set dx = Nothing
  54.   Set dy = Nothing
  55. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-5 20:41 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
。。。。。。。。。。

140805-两表比对问题.rar

15.93 KB, 下载次数: 87

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-5-3 05:12 , Processed in 0.058719 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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