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. 系统wmiprvse.exe占用CPU非常高,求解决

    1.wmiprvse.exe是微软Windows操作系统的一部分.用于通过WinMgmt.exe程序处理WMI操作.文件位置有二处: C:\WINDOWS\system32\wbem\wmiprvse ...

  2. OKHttpUtil工具类

    导入jar包下载链接 http://square.github.io/okhttp/ package com.common.util; import java.io.IOException; impo ...

  3. git 对比两个commit 之间的差异

    git 对比两个commit 之间的差异 比较两个版本之间的差异 git diff commit-id-1 commit-id-2 > d:/diff.txt 结果文件diff.txt中: &q ...

  4. 使用Python登录Github网站

    在下面的代码中, 展示了使用Python脚本登录Github的方法. 如果需要登录别的网站,那么请使用Chrome的Inspect的功能寻找到目标的object,对代码进行替换. 代码先登录了gith ...

  5. 微信小程序的同步操作

    小程序里,大多数操作都是异步操作,一些重要的操作,如从网上获取重要变量值,必须要保证有值,后续操作才有意义.但异步操作,又必须把处理放到回调中,代码可读性降低,而且和大多数正常逻辑相背. 折腾了两天, ...

  6. java command line error opening registry key 'Software\JavaSoft\Java Runtime Environment' java.dll

    C:\Users\huxxxxchan>javaError: opening registry key 'Software\JavaSoft\Java Runtime Environment'E ...

  7. Eureka服务注册中心相关错误com.sun.jersey.api.client.ClientHandlerException: java.net.ConnectException: Connection refused: connect

    启动项目报错如下 原因: 在默认设置下,Eureka服务注册中心也会将自己作为客户端来尝试注册它自己,所以会出现 com.sun.jersey.api.client.ClientHandlerExce ...

  8. 基于CentOS搭建VNC远程桌面服务

    系统要求:CentOS 7.2 64 位操作系统 安装.启动 VNC VNC 远程桌面原理 名词解释: Xorg:在 Linux 用户中非常流行,已经成为图形用户程序的必备条件,所以大部分发行版都提供 ...

  9. primary库新增数据文件后,standby库无法创建文件并终止数据同步

    主库是RAC环境,使用asm存放数据文件,备库是操作系统本地文件系统存放数据文件.在主库执行以下操作: SQL> alter tablespace ysdv add datafile '+dat ...

  10. java中的synchronized同步代码块和同步方法的区别

    下面这两段代码有什么区别? //下列两个方法有什么区别 public synchronized void method1(){} public void method2(){ synchronized ...