Excel:重复名次也可以查姓名成绩
发布时间:2023-04-04 09:05:40
当老师的,对分析学生成绩大概有瘾。这不,本来我们已经把学生各学科的成绩、总分、名次都排出来了,并按照总分进行了升序排序,但现在又有任课老师过来要求希望能够把自己学科的前10名的学生姓名及成绩找出来。按理说,这个要求并不是很困难,但是麻烦就在于学生各科名次有当老师的,对分析学生成绩大概有瘾。这不,本来我们已经把学生各学科的成绩、总分、名次都排出来了,并按照总分进行了升序排序,但现在又有任课老师过来要求希望能够把自己学科的前10名的学生姓名及成绩找出来。按理说,这个要求并不是很困难,但是麻烦就在于学生各科名次有可能相同,这样的话,前10名的学生其实不一定是10个人,有可能更多。每个学科都要这么做的话,工作量也不小,所以,还是得靠函数和公式来帮忙。
图1 原始成绩表
原始的成绩表如图1所示。姓名位于C2:C92单元格,语文成绩位于D2:D92单元格区域。我们就以查找语文学科的前10名成绩及学生姓名为例。为方便比较结果,图1中我们已经将数据按语文成绩降序进行了排序,实际操作中是不需要事先排序的。
一、名次表的建立
前面我们说过,我们不太容易确定排在前10名的学生共有多少,所以,我们需要使用公式将它们找出来。当然,最好顺便将名次表填写出来。完成结果如图2所示。
图2 成绩排序
将鼠标定位于X3单元格,然后在编辑栏输入公式“=TEXT(SUMPRODUCT(($D$2:$D$92>=LARGE($D$2:$D$92,ROW(1:1)))/COUNTIF($D$2:$D$92,$D$2:$D$92)),"第G/通用格式名")”,回车后就可以得到“第1名”的结果。选定X3单元格,向下拖动其填充句柄至出现“第11名”为止。
这里用到了几个函数,感觉上比较复杂。其实思路是这样的:“ROW(1:1)”的结果是“1”,而“LARGE($D$2:$D$92,1)”的结果是在指定的单元格区域中最大的一个数;那么公式中“($D$2:$D$92>=LARGE($D$2:$D$92,ROW(1:1)))”可以理解为拿D2:D92单元格区域中的数据与该区域中最大值比较,大于或等于该值及小于该值的则会分别以“TRUE”、“FALSE”的结果保存在一个数组中。
公式中“COUNTIF($D$2:$D$92,$D$2:$D$92))”部分则会统计D2:D92单元格区域中每一个数值出现的次数,也分别保存到一个数组中。所以,我们所用公式中“SUMPRODUCT(($D$2:$D$92>=LARGE($D$2:$D$92,ROW(1:1)))/COUNTIF($D$2:$D$92,$D$2:$D$92))”在执行时会得到一个类似于“SUMPRODUCT({TRUE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;…}/{1;1;2;2;1;2;2;1;2;2;2;2;1;…})”的结果。两个数组中的对应的数据分别相除,再将所有的商相加,正是分数所对应的名次。这种方法即使名次是并列的,也不会影响显示效果。
至于最外层的TEXT函数,则是将得到的结果转换为按指定数字格式表示的文本。也就是本来内层公式运算的结果是数字“1”,现在我们将它显示为“第1名”。
二、分数的查找
将鼠标定位于Y3单元格,在编辑栏中输入如下公式“=INDEX($D$2:$D$92,MATCH(LARGE($D$2:$D$92 1/ROW($D$2:$D$92),ROW(1:1)),$D$2:$D$92 1/ROW($D$2:$D$92),0))”,然后按下“Ctrl Shift Enter”快捷键,完成数组公式的输入。这一步很关键的,否则不会出现正确的结果。
向下拖动Y3单元格的填充句柄向下至最后一个单元格完成公式的复制。
我们还是简单解释一下公式的思路。
由于D2:D92区域中有很多数据是重复的,这给我们造成了困难。所以,我们要想办法使每一数据都变成唯一。公式中“$D$2:$D$92 1/ROW($D$2:$D$92)”就是给D2:D92区域中每一个数据都加了该数据对应行数的倒数。由于每一数据对应的行数是不一样的,这样,就会使每一数据都变成了唯一的值,并保存到了一个数组中。
公式中的“LARGE($D$2:$D$92 1/ROW($D$2:$D$92),ROW(1:1))”还是返回了上面所得数组中的最大值。本例中的结果是“{96.5}”。
公式中“MATCH(LARGE($D$2:$D$92 1/ROW($D$2:$D$92),ROW(1:1)),$D$2:$D$92 1/ROW($D$2:$D$92),0)”返回的是刚刚得到的最大值在数组中的位置。本例中的结果是“{1}”。
这样,其实Excel最后执行的查询就是“INDEX($D$2:$D$92,1)”了,自然可以返回在$D$2:$D$92区域中的第一个值了。
三、姓名的查找
将鼠标定位于Z3单元格,在编辑栏中输入公式“=INDEX($C$2:$C$92,MATCH(LARGE($D$2:$D$92 1/ROW($D$2:$D$92),ROW(1:1)),$D$2:$D$92 1/ROW($D$2:$D$92),0))”,同样按下“Ctrl Shift Enter”快捷键完成数组公式的输入。
向下拖动Z3单元格的填充句柄向下至最后一个单元格完成公式的复制。最后的效果如图3所示。
图3 完成公式的复制
其实您肯定已经明白了,姓名的查找与前面分数的查找是一样的。公式本身也没有什么大的变化。所以,明白了前面的方法,要查找别的什么东西也就方便了。
其它的学科可以照此办理。只要注意变换一下公式中的单元格区域就可以了,我这里就不罗嗦了。


猜你喜欢
- 很多的小伙伴都会在网上进行飞天茅台的请购但是很难,所以今天就给你们带来了网上抢飞天茅台技巧,如果你还在为抢不到茅台酒而困扰的话就赶快来试试吧
- 我们在使用wps演示做PPT的时候,使用在各种场合。其中不乏用来做宣传,在这种情况下我们往往需要它自动反复的播放,那么这个自动功能是怎么设置
- 在word文档操作中,有时需要调整字符间距,可以通过word提供的字符间距设置功能来更改字符的间距。对于刚从其它版本转型过来的应该就不会太懂
- 如果在使用Excel时,不小心误点了某个菜单命令,此时只要不松开鼠标将其移动到菜单外即可取消执行该命令。例如,单击菜单“工具→保护→保护工作
- 3月29日消息 经过6个月的消费者版测试,微软宣布推出Windows 10 1809的企业版服务。Windows 10更新十月版(v1809
- 上期内容我们介绍了条件数据快速填充颜色的便捷方法,那今天,再来带大家一起了解一下如何给Excel表格批量添加下划线的小技巧吧~首先,全选表格
- 我们在使用富士通电脑的时候,如果因为系统无法正常使用出现故障的问题需要重新安装操作系统的话,对于这种问题小编觉得如果是使用U盘安装的操作系统
- 1月28日消息 据外媒报道,苹果昨日发布了适用于 Win10 的 iCloud 新版本,基于多个报告和更新的发行说明,苹果有望引入一个专为
- 前面小编为大家介绍了mac的语音备忘录功能,不知道大家还记不记得,先帮大家回顾一下:mac小白快来看!送你一份关于mac语音备忘录的使用指南
- 如何在Mac的Word 2008中使用自动断字?Mac的Word 2008包括一个广泛的连字词典,您可以手动(默认)或自动使用它。除非您对连
- flash在各个浏览器中的作用都非常的大,它绝对了是否可以进行视频的播放,那么该怎么在谷歌浏览器上使用flash呢?下面就给你们带来了详细方
- 其实用Excel打印工资条,归根结底就是让Excel制作的工资表格中,一行工资细目数据,一行员工的记录。如果在每一个员工数据的上面插入一行工
- VMware虚拟机怎么分析bug记录?虚拟机会有一些莫名其妙的问题,好在可以在Windows7正常系统中验证问题的范围,外围正常,就是虚拟机
- 最近有Win10用户反映,C盘空间总是不够用,检查了下发现C盘根目录下有个hiberfil.sys文件,有几G之大,用户想要将其删除,但又不
- wps软件一直是用户经常使用的一款办公软件,给用户带来了许多的便利,在wps软件中用户可以编辑文档、表格以及个人简历等文件,再加上这款办公软
- 怎样使用快递100打印电子面单?快递100是一款综合性快递物流服务网站。快递100集国内最常用的快递和物流公司,还提供快递单打印等各种快递工
- excel滚动条在默认情况下,启动Excel就有水平和垂直滚动条。如果遇到excel滚动条不见了,隐藏了之类,可以参考下面的excel滚动条
- 我们在运用WPS编辑文档时,为了使文档简洁美观,或者为了方便计算字数,我们通常需要用到WPS的页边距功能,这款功能不只是我们平时设置文档边距
- 要熟练地使用Excel 2019就要先学会它的启动方法,然后从不同的启动方法中选择快速简单的一种来完成Excel 2019的启动。启动Exc
- 奇乐云APP如何使用?齐乐云是一款很棒的网盘资源解析软件,很多刚刚下载这款软件的小伙伴还不知道如何使用,我们今天就一起来看看齐乐云APP的使