获取两个数据的交集_如何在Excel中对比数据的方法,可在相同或者不同的工作表中完成...

经常被人问到怎么对两份Excel数据进行比对,提问的往往都很笼统;在工作中,有时候会需要对两份内容相近的数据记录清单进行比对,需求不同,比对的的目标和要求也会有所不同。下面小编根据几个方法介绍一下Excel表格中数据比对和查找的技巧。

应用案例一:比对取出两表的交集(相同部分)

Sheet1中包含了一份数据清单A,sheet2中包含了一份数据清单B,要取得两份清单共有的数据记录(交集),也就是要找到两份清单中的相同部分。

fc7e89e3c5a42417a38ae0a98549ff70.png

方法1:高级筛选

高级筛选是处理重复数据的利器。

选中第一份数据清单所在的数据区域,在功能区上依次单击【数据】——【高级】(2003版本中菜单操作为【数据】——【筛选】——【高级筛选】),出现【高级筛选】对话框。

在对话框中,筛选【方式】可以根据需求选取,例如这里选择“将筛选结果复制到其他位置”;【列表区域】就是之前所选中的第一份数据清单A所在的单元格区域;【条件区域】则选取另外那份清单B所在的单元格区域。如下图所示:

83b534ee1f2e0a31519c469bb1dad074.png

点击【确定】按钮后,就可以直接得到两份清单的交集部分,效果如下图。其中两个清单中虽然都有【西瓜】和【菠萝】,但是由于数量不一致,所以没有作为相同记录被提取出来。

c85a1e783768ab7052b610bafc078b8d.png

这个操作的原理,就是利用了高级筛选功能对于匹配指定条件的记录进行筛选的功能,把两张表中的任意一张作为条件区域,在另外一张表中就能筛选出与之相匹配的记录,忽略掉其他不相关的记录。

需要注意的是,使用高级筛选的时候务必注意两个清单的标题行要保持一致(高级筛选中作为条件区域的前提),并且在选取【列表区域】和【条件区域】的时候都要把标题行的范围包含在其中。

方法2:公式法

使用公式进行比对的方法有很多,如果是单列数据对比比较常用的函数是COUNTIF函数,如果是多列数据记录对比,SUMPRODUCT函数比较胜任。

在其中一张清单的旁边输入公式:

=SUMPRODUCT((A2&B2=Sheet2!A$2:A$13&Sheet2!B$2:B$13)*1)

并向下复制填充。其中的Sheet2!A$1:A$13和Sheet2!B$2:B$13是另一张清单中的两列数据区域,需要根据实际情况修改。公式结果等于1的记录就是两个清单的交集部分,如下图所示:

e06c21cc453f7bac1a6827181b18da6f.png

应用案例二:取出两表的差异记录

要在某一张表里取出与另一张表的差异记录,就是未在另外那张清单里面出现的部分,其原理和操作都和上面第一种场景的差不多,所不同的只是筛选后所选取的集合正好互补。

方法1:高级筛选

先将两个清单的标题行更改使之保持一致,然后选中第一份数据清单所在的数据区域,在功能区上依次单击【数据】——【高级】,出现【高级筛选】对话框。在对话框中,筛选方式选择“在原有区域显示筛选结果”;【列表区域】和【条件区域】的选取和前面场景1完全相同,如下图所示:

c33553a2e11d2ee0e95b41a0affc8a68.png

点击【确定】完成筛选,将筛选出来的记录全部选中按【Del】键删除(或做标记),然后点击【清除】按钮(2003版本中为【全部显示】按钮)就可以恢复筛选前的状态得到最终的结果,如下图所示:

64e116202da0476191d41ebb2e3fa70d.png

点击【确定】按钮后,就可以直接得到两份清单的交集部分,效果如下图。其中两个清单中虽然都有【西瓜】和【菠萝】,但是由于数量不一致,所以没有作为相同记录被提取出来。

a7c85cf155c57ca22887c87c9bc0d986.png

法2:公式法

使用公式的话,方法和场景1完全相同,只是最后需要提取的是公式结果等于0的记录。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以在Java使用Collection的retainAll()方法来比较两个List对象并获取它们的差异集合。具体步骤如下: 1. 先创建两个List对象list1和list2,假设它们的元素类型是String。 2. 调用list1的retainAll(list2)方法,该方法会修改list1,使其只保留list2也包含的元素,也就是list1和list2的交集。此时list1只包含两个List对象共有的元素。 3. 调用list2的retainAll(list1)方法,该方法会修改list2,使其只保留list1也包含的元素,也就是list1和list2的交集。此时list2只包含两个List对象共有的元素。 4. 调用list1的removeAll(list2)方法,该方法会从list1删除list2也包含的元素,也就是list1除去两个List对象共有的元素后剩余的元素,即list1和list2的差集。 5. 调用list2的removeAll(list1)方法,该方法会从list2删除list1也包含的元素,也就是list2除去两个List对象共有的元素后剩余的元素,即list2和list1的差集。 下面是示例代码: ```java List<String> list1 = new ArrayList<>(); list1.add("a"); list1.add("b"); list1.add("c"); List<String> list2 = new ArrayList<>(); list2.add("b"); list2.add("c"); list2.add("d"); List<String> intersection = new ArrayList<>(list1); intersection.retainAll(list2); // 取交集 List<String> difference1 = new ArrayList<>(list1); difference1.removeAll(list2); // 取差集 List<String> difference2 = new ArrayList<>(list2); difference2.removeAll(list1); // 取差集 System.out.println("list1和list2的交集:" + intersection); // 输出 [b, c] System.out.println("list1和list2的差集:" + difference1); // 输出 [a] System.out.println("list2和list1的差集:" + difference2); // 输出 [d] ``` 以上代码输出的结果为: ``` list1和list2的交集:[b, c] list1和list2的差集:[a] list2和list1的差集:[d] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值