https://jingyan.baidu.com/article/63f236281f17650208ab3d97.html

Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '员工基础报表数据范围
For j = 2 To 2028 '员工待遇统计表数据范围
If Sheets("old").Cells(i, 6) = Sheets("new").Cells(j, 6) Then
Sheets("old").Cells(i, 8) = "已存在" '存在时进行标记
End If
Next j
Next i
End Sub

前面插入一列"Index"序号

Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '员工基础报表数据范围
For j = 2 To 2028 '员工待遇统计表数据范围
If Sheets("old").Cells(i, 7) = Sheets("new").Cells(j, 7) Then
Sheets("old").Cells(i, 11) = "已存在" '存在时进行标记
Sheets("new").Cells(j, 11) = "源表已存在" '存在时进行标记 Sheets("old").Cells(i, 12) = i
Sheets("new").Cells(j, 12) = i
End If
Next j
Next i
End Sub

双重过滤,才能精准

Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '员工基础报表数据范围
For j = 2 To 2028 '员工待遇统计表数据范围
If Sheets("old").Cells(i, 4) = Sheets("new").Cells(j, 4) Then
If Sheets("old").Cells(i, 7) = Sheets("new").Cells(j, 7) Then
Sheets("old").Cells(i, 11) = "已存在" '存在时进行标记
Sheets("new").Cells(j, 11) = "源表已存在" '存在时进行标记 Sheets("old").Cells(i, 12) = i
Sheets("new").Cells(j, 12) = i
End If
End If
Next j
Next i
End Sub

成功匹配:

Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '员工基础报表数据范围
For j = 2 To 2028 '员工待遇统计表数据范围
If Sheets("old").Cells(i, 4) = Sheets("new").Cells(j, 4) Then
If Sheets("old").Cells(i, 7) = Sheets("new").Cells(j, 7) Then
Sheets("old").Cells(i, 11) = "已存在" '存在时进行标记
Sheets("new").Cells(j, 11) = "源表已存在" '存在时进行标记 Sheets("old").Cells(i, 12) = i
Sheets("new").Cells(j, 12) = i
End If
End If
Next j
Next i
End Sub

数值填充(大小写、双引号不能模糊匹配,需要改善)

Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '源表
For j = To 'overlay表
'If Sheets("old").Cells(i, 4) = Sheets("new").Cells(j, 4) Then
If Sheets("old").Cells(i, ) = Sheets("new").Cells(j, ) Then
Sheets("old").Cells(i, ) = Sheets("new").Cells(j, ).Value '存在时进行标记
End If
'End If
Next j
Next i
End Sub

改善后代码:

Option Compare Text
Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '源表
For j = To 'overlay表
'If Sheets("old").Cells(i, 4) = Sheets("new").Cells(j, 4) Then
If StrComp(Sheets("old").Cells(i, ).Value, Sheets("new").Cells(j, ).Value, ) = Then
Sheets("old").Cells(i, ) = Sheets("new").Cells(j, ).Value '存在时进行标记
End If
'End If
Next j
Next i
End Sub

或添加"Trim"函数过滤外侧空格

Option Compare Text
Sub 数据对比()
Dim i As Integer
Dim j As Integer
For i = To '源表
For j = To 'overlay表
'If Sheets("old").Cells(i, 4) = Sheets("new").Cells(j, 4) Then
If StrComp(Trim(Sheets("old").Cells(i, ).Value), Trim(Sheets("new").Cells(j, ).Value), ) = Then
Sheets("old").Cells(i, ) = Sheets("new").Cells(j, ).Value '存在时进行标记
End If
'End If
Next j
Next i
End Sub

再次改善代码,自动获取最后一行的长度

Option Compare Text
Sub 数据对比()
Dim sLength As Integer '记录源表长度
Dim dLength As Integer '记录目标表长度
Dim i As Integer
Dim j As Integer
sLength = Sheets("old").Cells(Rows.Count, "A").End(xlUp).Row
dLength = Sheets("new").Cells(Rows.Count, "A").End(xlUp).Row
Debug.Print "source sheet length:" & sLength
Debug.Print "dir sheet length:" & dLength For i = To sLength
For j = To dLength
'If Sheets("old").Cells(i, 4) = Sheets("new").Cells(j, 4) Then
If StrComp(Trim(Sheets("old").Cells(i, ).Value), Trim(Sheets("new").Cells(j, ).Value), ) = Then
Sheets("old").Cells(i, ) = Sheets("new").Cells(j, ).Value '存在时进行标记
End If
'End If
Next j
Next i End Sub

再次改善:声明工作表引用类型

Option Explicit
Option Compare Text
Sub 数据匹配导入()
'声明语句
Dim i As Integer
Dim j As Integer
Dim sLength As Integer '源工作表长度
Dim dLength As Integer '目标工作表长度
Dim sSheet As Sheet1 '源工作表
Dim dSheet As Sheet2 '目标工作表 '赋值语句
'Set sSheet = Sheets("old") 'old是源工作表的名称
'Set dSheet = Sheets("new") 'new是目标工作表的名称
Set sSheet = Sheets() '第一个工作表
Set dSheet = Sheets() '第二个工作表 '获取工作表总列数
sLength = sSheet.Cells(Rows.Count, "A").End(xlUp).Row
dLength = dSheet.Cells(Rows.Count, "A").End(xlUp).Row '打印总列数
Debug.Print "source sheet length:" & sLength
Debug.Print "dir sheet length:" & dLength Application.ScreenUpdating = False '关闭屏幕更新
For i = To sLength '第一行是标题行
For j = To dLength
If StrComp(Trim(sSheet.Cells(i, ).Value), Trim(dSheet.Cells(j, ).Value), ) = Then
sSheet.Cells(i, ) = dSheet.Cells(j, ).Value '将目标工作表的第二列赋值到源工作表的第二列
End If
Next j
Next i
Application.ScreenUpdating = True '重新开启屏幕更新 '数据匹配完成后弹出提醒
MsgBox "匹配完成!"
End Sub

Excel如何实现两个工作表数据的对比的更多相关文章

  1. Excel中如何在两个工作表中查找重复数据

    有时我们可能会在两种工作表中查找重复记录,当数据记录很多时,就必须通过简单的方法来实现.下面小编就与大家一起分享一下查看重复记录数据的方法,希望对大家有所帮助. 方法/步骤   为了讲解的需要,小编特 ...

  2. excel怎么并排查看两个工作表

    excel怎么并排查看两个工作表 excel怎么并排查看两个工作表?excel打开一个窗口想要同时查看两个工作表中的数据,类似于word中的分栏效果,该怎么实现呢?EXCEL是一个使用最多的办公软件, ...

  3. 我的excel是2003版本的,里边有sheet1、sheet2两个工作表,当使用GetOleDbSchemaTable获取表Schema时,结果是4个,分别为: sheet1 sheet1$ sheet2 sheet2$

    原帖地址:http://bbs.csdn.net/topics/310230098 ---------------------------------------------------------- ...

  4. EXCEL 如何将多个工作表或工作簿合并到一个工作表

    在使用Excel 时,我们经常需要将多个工作表或工作簿合并到一个工作表中,这样我们就能快速地对数据进行分析和统计.对于一般用户而言,除了复制每个工作表后再粘贴,没有其他什么方法了.如果只是合并少数几个 ...

  5. RDLC 微软报表 导出Excel时产生多个工作表 (worksheet)

    . I have added two obejcts data source to Report Viewer. 2. in RDLC i have created two tables and in ...

  6. 【Office】【Excel】将多个工作表合为一个工作表

    在工作表中按下alt+F11打开vba编辑窗口,在菜单栏中选择[插入]=>[模板],将下面的代码粘贴过去,然后运行即可 点击查看代码 Sub 合并当前工作簿下的所有工作表() On Error ...

  7. 20161212xlVBA工作表数据整理合并单元格

    Sub NextSeven_CodeFrame() '应用程序设置 Application.ScreenUpdating = False Application.DisplayAlerts = Fal ...

  8. 20161208xlVBA工作表数据导入Access

    Sub InsertToDataBase() Dim DataPath As String Dim SQL As String Const DataName As String = "yun ...

  9. excel表格中关于 撤销工作表保护密码

    利用宏处理,代码如下: Sub PasswordBreaker() Dim i As Integer, j As Integer, k As Integer Dim l As Integer, m A ...

随机推荐

  1. Cassandra的数据模型的理解

           Cassandra属于NoSQL数据库,NoSQL和传统关系型数据库不同,NOSQL偏好数据冗余,因为NoSQL一般无法做表关联查询. (1) keySpace 基本上可以将Keyspa ...

  2. sublime text3怎么安装Package Control

    sublime text3地址:https://packagecontrol.io/installation#st3 1.打开Preferences——Browse Packages,打开一个文件夹C ...

  3. Long polling failed, will retry in 16 seconds. appId: zeus-guard, cluster: default, namespaces: application, long polling url: null, reason: Get config services failed from···

    当dubbo应用启动之前, 如果apollo 未启动好,那么我们dubbo应用会一直等待,直到apollo准备就绪,注意其中轮询时间是从1,2,3,4,8,14,32, 方式一直增长,单位是s.

  4. windows10多桌面创建 切换 和分屏

    windows键+Tab 可以创建和切换新的桌面 win+ctrl+左右箭头 可以切换桌面 Aero Snap是Win7时代增加的一项窗口排列功能,俗称“分屏”.一个最简单例子,就是当你把窗口拖至屏幕 ...

  5. Django Web开发学习笔记(4)

    第四章 模板篇 上一章的内容,我们将HTML的代码和Python代码都混合在了在view.py的文件下.但是这样做的坏处无疑是明显的,引用DjangoBook的说法: 对页面设计进行的任何改变都必须对 ...

  6. 应用程序默认安装在C盘后启动时提示权限不足想起的。。。

    最近不少经销商用户反映,在使用win 7的系统的电脑上安装我们的软件后,开启系统时提示权限不足,无法启动软件. 而在xp系统下则没有这个问题,原因在于我们将系统的默认安装路径选择在了C盘了,而win ...

  7. [Aaronyang] 写给自己的WPF4.5 笔记16[多线程]

      =============潇洒的版权线==========www.ayjs.net===== Aaronyang ========= AY =========== 安徽 六安 杨洋 ======= ...

  8. [k8s]svc里知识点小结

    svc里面涉及到的概念较多一些,总结如下

  9. System.SerializableAttribute

    System.SerializableAttribute 串行化是指存储和获取磁盘文件.内存或其他地方中的对象.在串行化时,所有的实例数据都保存到存储介质上,在取消串行化时,对象会被还原,且不能与其原 ...

  10. python bottle框架 解决跨域问题的正确方式

    经查询,网上有几种说法 https://www.cnblogs.com/EmptyFS/p/6138923.html 我首先查到的就是这个,我采用了文中所说的修改源码的方式, 但是经测试发现,修改源码 ...