VBA二次学习笔记(2)——两个Excel表内容比较
说明(2018-9-3 22:38:58):
1. 就是之前问同事要来的作业,有两个格式一样的Excel文件,一个是正确答案,一个是员工作答的。通过代码将两个文件进行比对,把不同之处列出来。
正文:
Sub test1()
Dim wb1 As Worksheet
Dim wb2 As Worksheet
Dim wb As Worksheet
Set wb1 = Workbooks("1.xlsx").Sheets()
Set wb2 = Workbooks("2.xlsx").Sheets()
Set wb = Workbooks("test.xlsm").Sheets()
Dim n As Integer
n =
For i = To
If wb1.Range("b" & i).Value <> wb2.Range("b" & i).Value Then
wb.Range("a" & n).Value = wb1.Range("a" & i).Value
wb.Range("b" & n).Value = wb1.Range("b" & i).Value
wb.Range("c" & n).Value = wb2.Range("b" & i).Value
n = n +
End If
Next For i = To
If wb1.Range("b" & i).Value <> wb2.Range("b" & i).Value Then
wb.Range("a" & n).Value = wb1.Range("a" & i).Value
wb.Range("b" & n).Value = wb1.Range("b" & i).Value
wb.Range("c" & n).Value = wb2.Range("b" & i).Value
n = n +
End If
Next
End Sub
效果:
1.xlsx和2.xlsx,有两个数字不一样

在宏文件所在的Excel里的显示结果:

总结:
1. 主要使用了获取工作簿的方法WorkBooks();用了两个for循环,因为表格不连续;用了一个变量n,控制在主表中向下排列不同数据。
2. WorkBooks()获取工作簿需要文件打开,下一步可以使用open方法,在不用提前打开文件的条件下完成操作。
附件:
Sub test1()
Dim wb1 As Worksheet
Dim wb2 As Worksheet
Dim wb As Worksheet
Dim fileCheck, fileAnswer As String
fileCheck = "Cassie Jiang.xlsx"
fileAnswer = "Correct Answer.xlsx"
'判断文件是否已经打开,如果打开,提示关闭
Set sheetCheck = Workbooks.Open(ThisWorkbook.path + "\" + fileCheck).Sheets()
Set sheetAnswer = Workbooks.Open(ThisWorkbook.path + "\" + fileAnswer).Sheets()
Set sheetError = Workbooks(fileAnswer).Sheets()
Dim n As Integer
n =
For i = To
If LCase(Replace(sheetCheck.Range("d" & i).Value, " ", "")) <> LCase(Replace(sheetAnswer.Range("d" & i).Value, " ", "")) Then
sheetError.Range("a" & n).Value = sheetCheck.Range("D6").Value '姓名
sheetError.Range("b" & n).Value = sheetCheck.Range("b" & i).Row 'Row#
sheetError.Range("c" & n).Value = sheetCheck.Range("b" & i).Value 'Item(b3,c3合并了,所以要用b3)
sheetError.Range("d" & n).Value = sheetCheck.Range("d" & i).Value 'Trainee's Answer
sheetError.Range("e" & n).Value = sheetAnswer.Range("d" & i).Value 'Correct Answer
n = n +
End If
Next For i = To
If LCase(Replace(sheetCheck.Range("d" & i).Value, " ", "")) <> LCase(Replace(sheetAnswer.Range("d" & i).Value, " ", "")) Then
sheetError.Range("a" & n).Value = sheetCheck.Range("D6").Value
sheetError.Range("b" & n).Value = sheetCheck.Range("b" & i).Row
sheetError.Range("c" & n).Value = sheetCheck.Range("c" & i).Value
sheetError.Range("d" & n).Value = sheetCheck.Range("d" & i).Value
sheetError.Range("e" & n).Value = sheetAnswer.Range("d" & i).Value
n = n +
End If
Next For i = To
If LCase(Replace(sheetCheck.Range("d" & i).Value, " ", "")) <> LCase(Replace(sheetAnswer.Range("d" & i).Value, " ", "")) Then
sheetError.Range("a" & n).Value = sheetCheck.Range("D6").Value
sheetError.Range("b" & n).Value = sheetCheck.Range("b" & i).Row
sheetError.Range("c" & n).Value = sheetCheck.Range("c" & i).Value
sheetError.Range("d" & n).Value = sheetCheck.Range("d" & i).Value
sheetError.Range("e" & n).Value = sheetAnswer.Range("d" & i).Value
n = n +
End If
Next Workbooks(fileCheck).Close
Workbooks(fileAnswer).Close (True) End Sub
修改后:
Sub Check()
Dim sheetCheck, sheetAnswer, sheetError As Worksheet '筛选、获取trainee文件名
For i = To Workbooks.Count
If Workbooks(i).Name <> "Correct Answer.xlsx" And Workbooks(i).Name <> "micro.xlsm" And LCase(Workbooks(i).Name) <> "personal.xlsb" Then
Set sheetCheck = Workbooks(i).Sheets()
Exit For
End If
Next
Set sheetAnswer = Workbooks("Correct Answer.xlsx").Sheets() '获取Answer工作表
Set sheetError = Workbooks("Correct Answer.xlsx").Sheets() '获取Error工作表 '对比前清除Error比对记录
Dim m As Integer
m = sheetError.UsedRange.Rows.Count
sheetError.Rows("2:" & m).ClearContents '设置Error里的行号
Dim n As Integer
n = '循环对比
For i = To
If LCase(Replace(sheetCheck.Range("d" & i).Value, " ", "")) <> LCase(Replace(sheetAnswer.Range("d" & i).Value, " ", "")) Then
sheetError.Range("a" & n).Value = sheetCheck.Range("D6").Value '姓名
sheetError.Range("b" & n).Value = sheetCheck.Range("b" & i).Row 'Row#
sheetError.Range("c" & n).Value = sheetCheck.Range("b" & i).Value 'Item(b3,c3合并了,所以要用b3)
sheetError.Range("d" & n).Value = sheetCheck.Range("d" & i).Value 'Trainee's Answer
sheetError.Range("e" & n).Value = sheetAnswer.Range("d" & i).Value 'Correct Answer
n = n +
End If
Next For i = To
If LCase(Replace(sheetCheck.Range("d" & i).Value, " ", "")) <> LCase(Replace(sheetAnswer.Range("d" & i).Value, " ", "")) Then
sheetError.Range("a" & n).Value = sheetCheck.Range("D6").Value
sheetError.Range("b" & n).Value = sheetCheck.Range("b" & i).Row
sheetError.Range("c" & n).Value = sheetCheck.Range("c" & i).Value '这里是c了
sheetError.Range("d" & n).Value = sheetCheck.Range("d" & i).Value
sheetError.Range("e" & n).Value = sheetAnswer.Range("d" & i).Value
n = n +
End If
Next End Sub
VBA二次学习笔记(2)——两个Excel表内容比较的更多相关文章
- VBA二次学习笔记(1)——文件操作
说明(2018-9-1 11:20:46): 1. 上班三个月了,累的一逼,真的是钱少事多离家远,每天早上六点起,晚上八点回.哎,少壮不努力啊! 2. 三个月没写博客了,上一篇已经是5.29的了,真的 ...
- VBA二次学习笔记(3)——批量合并单元格
说明(2018-9-16 22:17:49): 1. 昨天运动会,100米八个人跑了第五,400米五个人跑了第三,得了个榨汁机.终于结束了哈哈哈!之前一个星期紧张的天天拉肚子,真是没出息..不过养成了 ...
- 毕业设计 之 二 PHP学习笔记(一)
毕业设计 之 二 PHP学习笔记(一) 作者:20135216 平台:windows10 软件:XAMPP,DreamWeaver 一.环境搭建 1.XAMPP下载安装 XAMPP是PHP.MySQL ...
- 《Linux内核设计与实现》第一、二章学习笔记
<Linux内核设计与实现>第一.二章学习笔记 姓名:王玮怡 学号:20135116 第一章 Linux内核简介 一.关于Unix ——一个支持抢占式多任务.多线程.虚拟内存.换页.动态 ...
- 《Linux内核设计与实现》 第一二章学习笔记
<Linux内核设计与实现> 第一二章学习笔记 第一章 Linux内核简介 1.1 Unix的历史 Unix的特点 Unix很简洁,所提供的系统调用都有很明确的设计目的. Unix中一切皆 ...
- vlookup函数基本使用--如何将两个Excel表中的数据匹配;excel表中vlookup函数使用方法将一表引到另一表
vlookup函数基本使用--如何将两个Excel表中的数据匹配:excel表中vlookup函数使用方法将一表引到另一表 一.将几个学生的籍贯匹配出来‘ 二.使用查找与引用函数 vlookup 三. ...
- 从两张Excel表所想到的
从两张Excel表所想到的 前几日,客服妹子发过来几张表,让我给她做下匹配,然后做了,想了,便有了这篇博文,不由感慨,看似简简单单的两张Excel表其实藏着好多东西,记叙如下,与君共勉. 最初的需求: ...
- 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记
回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...
- 【web开发学习笔记】Structs2 Action学习笔记(两)
action学习笔记2-大约action method讨论 Action运行的时候并不一定要运行execute方法,能够在配置文件里配置Action的时候用method=来指定运行哪个方法 也能够在u ...
随机推荐
- [数据库]Sqlite使用入门
官网的文档结构十分恶劣,大概翻了一下,提供入门指引. 0. sqlite的安装 根据自身情况,在官网下载32位/64位的dll文件以及sqlite-tools-win32-x86-3240000.zi ...
- AGC 027B.Garbage Collector(贪心)
题目链接 \(Description\) 坐标轴正半轴上有\(n\)个垃圾,位置分别是\(x_i\).在原点处有一个垃圾桶.一个机器人要从原点出发,将所有垃圾带到垃圾桶(原点)处. 机器人可以在坐标轴 ...
- BZOJ.3504.[CQOI2014]危桥(最大流ISAP)
BZOJ 洛谷 这种题大多是多源多汇跑网络流.往返\(a_n/b_n\)次可以看做去\(a_n/b_n\)次,直接把危桥能走的次数看做\(1\). 先不考虑别的,直接按原图建模:危桥建双向边容量为\( ...
- Java并发编程(五)-- Java内存模型补充
前面我们已经介绍了:当对象和变量存储到计算机的各个内存区域时,必然会遇到的两个问题及解决方法 共享对象的可见性-- 解决方法:使用java volatile关键字 共享对象的竞争现象 -- 解决方法: ...
- 使用requests进行模拟登陆
import re import requests header = { 'User-Agent': "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWe ...
- 谈一谈java里面的反射机制
首先来看看百度百科中是如何定义的: JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方 ...
- vmware ubuntu重置root密码
1.重启ubuntu,按住shift(开机启动时) 2.选择recovery mode,enter 3.root选择root drop to root shell prompt 4.进入shell界面 ...
- mysql 设置、更改、找回密码
1,新装mysql,添加密码 mysqladmin -u root password NEWPASSWORD 2,记得旧密码,改密码 mysqladmin -u root -p'OLDPASSWORD ...
- 多重背包--java
多重背包 有N种物品和一个容量为V的背包.第i种物品最多有n[i]件可用,每件费用是c[i],价值 是w[i].求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,且价值总和最大母函数的思想也 ...
- 自定义simple_tag和filter在html中渲染出来的联系和区别
关于 simple_tag: 1,在app下创建一个(templatetags)目录,(被引用的模块必须放在该目录下,且目录名称不可更改): 2,创建任意py文件: 3,创建template对象: f ...