当前位置:首页 > 技术文章 > 正文内容

Excel中多行多列数据去重有高招(多行多列取不重复值列表)

一些数据会重复出现在表格的不同行列中。如老师任课表,由于一些老师会在多个班级任教,因此其姓名会在表中重复出现,现在需要将所有一线任课老师的姓名从表中提取出来,这就会涉及去重问题。如何实现去重呢?下面笔者以Excel 2019为例介绍具体的操作方法。假设学校无重名的老师,若有则需要先标注以示区别(如张三1,张三2)。

文| 俞木发

○ 方法1. 删除重复值法

  用Excel内置的“删除重复值”去重很方便。不过,这个方法要求数据均在一列才行。因此对于多行多列的数据,需要先将去重数据归集在一列中。比如下面是某校老师任课表,现在需要在J列中列出所有任课老师的去重名单(图1)。


  定位到B10单元格并输入公式“=C2”,然后向右填充到H10单元格,选中B10:H10数据区域,向下填充公式,直到B列单元格中出现数字0为止,这样在B列中便可以引用全部老师的姓名(图2)。


  公式解释:

  这里使用“=”在B10单元格中开始引用下一列的数据,公式下拉后B10:H10就会依次引用各自下一列的数据,直到没有数据为止(单元格显示0),所以最终在B列中可以引用所有任课老师的数据。

  继续选中B2:B57区域(总共56条数据,B58单元格中的数字为0)中的数据并复制,接着定位到J2单元格,依次点击“开始→粘贴→值”,选中J列中的数据,依次点击“数据→删除重复值”,在弹出的窗口中勾选“列J”,点击“确定”(图3)。


  这样J列中的重复值就自动被剔除,在该列中就可以保留不重复的老师名单了(图4)。如果后续名单发生了变化,只要重复上述操作,然后再次执行去重操作即可。


○ 方法2. 函数法 

  上述方法是手动去重,如果名单发生变化,还需要再次去重。如果要实现去重的自动化,可以借助于函数来实现。

  定位到K2单元格并输入公式“=OFFSET(B$2,MOD(ROW(A1)-1,8),INT((ROW(A1)-1)/8))”,然后下拉填充到单元格显示数字0为止(图5)。


  公式解释:

  先使用MOD函数对“(行数-1)”值和除数“8”(对应原始数据包含老师名单的行数,如本例是8行,第2行-第9行)取余,然后将其作为OFFSET函数偏移的列号。因为原始数据为8行,所以每8行会向右偏移1列引用。接着使用INT函数对“(行数-1)/8”数值向下取整,将其作为OFFSET函数偏移的行号数据。引用的基准是B$2(行锁定),这样下拉公式时,OFFSET就会在K列依次引用B2:H10区域中的数据。

  继续定位到L2单元格,输入公式“=IFERROR(INDEX($K$2:$K$100,MATCH(,COUNTIF($L$1:L1,$K$2:$K$100),)),"")”,然后定位到公式地址栏,按下“Ctrl+Shift+Enter”组合键完成数组公式的输入,接着下拉填充公式,直到单元格显示为0,完成去重名单的提取(图6)。


  公式解释:

  先使用COUNTIF函数以“$L$1:L1”为计数条件,计数区域是“$K$2:$K$100”。这里K100数字至少要比图5中OFFSET函数引用时出现的数字0单元格行号的数字要大。然后将这个计数作为MATCH函数的引用数值,再将其作为INDEX函数引用的行号值。最后在外层嵌套IFERROR函数,对没有引用数值的单元格显示为空。这样作为数组公式使用时,就可以对$K$2:$K$100区域的数据完成去重操作。

○ 方法3. VBA法  

  多行多列数据去重,实际操作是先将数据组成一列,然后去重,在VBA中可以借助于RemoveDuplicates函数来快速实现。

  先到“
https://share.weiyun.com/BYDj7Qhx”下载所需的代码,接着按下“Alt+F11”快捷键打开VBA编辑窗口,依次点击“插入→模块”,将下载的代码粘贴到代码框中(图7)。


  代码解释:

  先设置行列变量,列内容是第2列→第8列(即B:H列),行内容是第2行→第9行(请根据实际单元格内容设置)。然后遍历这些行列中的内容,将其提取到I列中保存,最后使用RemoveDuplicates函数对I列的内容去重。

  返回到Excel窗口中,依次点击“开发工具→宏→去重”,点击“执行”,这样VBA代码就会将所有老师的数据复制到I列并完成去重操作了(图8)。CF


原文刊登于2022 年 10 月 1 日出版《电脑爱好者》第 19 期

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/4342.html

分享给朋友:

“Excel中多行多列数据去重有高招(多行多列取不重复值列表)” 的相关文章

Windows下配置Nginx开机自启动

如何安装、配置网站就不说了,文章主要讲讲windows中如何让nginx开机自启动1.windows中配置nginx开机启动需要借助Windows Service Wrapper工具。可以通过地址http://repo.jenkins-ci.org/releases/com/sun/winsw/wi...

PHP日志记录

背景在生产环境中日志的重要性显而易见,能快速定位问题和程序的调优。在LNMP架构中怎么记录好程序中的错误日志。设置error_log记录PHP日志信息#将会向PHP报告发生的每个错误 error_reporting = E_ALL #关闭页面显示才能将错误回写到日志文件 display_err...

08《Nginx 入门教程》Nginx 的 Http 模块介绍(中)

在前面介绍完 post-read、server-rewrite、find-config、rewrite 和 post-rewrite 阶段后,我们将继续学习 preaccess 和 access 两个阶段,中间会涉及部分模块,一同进行说明。1. preaccess 阶段在 preaccess 阶段在...

Nginx负载均衡安全配置说明2 nginx负载均衡配置文件

上一节,我们对Nginx安全配置的几个知识点做了一个说明,例如限制IP访问、文件目录禁止访问限制、需要防止DOS攻击、请求方法的限制和限制文件上传的大小这个进行了一个分析说明,详细的文章请关注我的头条号:一点热,在里面看回之前的文章,快速入口Nginx负载均衡的一些安全配置说明其实,配置Nginx的...

轻量级日志平台 Loki 2.3 发布:15 倍最近数据查询速度提升

一、前言Loki v2.3.0 中添加了出色的新功能,进行了 bug 修复。除此之外,性能也得到了提升。二、自定义保留规则Loki 中的保留对于集群来说一直是全局的,并推迟到底层对象存储。Loki 现在可以通过 Compactor 组件处理保留。 你可以配置每个租户和每个流的保留时间。 这些不同的保...

VUE3前端开发入门系列教程

一直以来使用ThinkJS开发,使用Semantic-UI手写代码,又缺少一些table等插件,好累。平时使用NodeJS开发后端较多,一直有接触VUE想法,总是不得入门(可能是思维固化了),再次深入研究,直接从VUE3入手,并借这次机会写个入门系列教程,一是做个笔记备查,二是与大家分享。初次入门V...