WEB开发网
开发学院软件教学办公软件Excel Excel:重复名次也可以查姓名成绩 阅读

Excel:重复名次也可以查姓名成绩

 2008-01-11 22:06:19 来源:WEB开发网   
核心提示: 公式中“COUNTIF($D$2:$D$92,$D$2:$D$92))”部分则会统计D2:D92单元格区域中每一个数值出现的次数,也分别保存到一个数组中,Excel:重复名次也可以查姓名成绩(2),所以,我们所用公式中“SUMPRODUCT(($D$2:

公式中“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所示。

Excel:重复名次也可以查姓名成绩

图3 完成公式的复制(点击看大图)

其实您肯定已经明白了,姓名的查找与前面分数的查找是一样的。公式本身也没有什么大的变化。所以,明白了前面的方法,要查找别的什么东西也就方便了。

其它的学科可以照此办理。只要注意变换一下公式中的单元格区域就可以了,我这里就不罗嗦了。

上一页  1 2 

Tags:Excel 重复 名次

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接