> 文章列表 > 对于排名,很多时候并不是一个RANK能搞定

对于排名,很多时候并不是一个RANK能搞定

对于排名,很多时候并不是一个RANK能搞定

对的,RANK函数确实是用的频率最高的,但是还有更多的场景你知道么?

一、降序排列

最常见的就是降序排列了,比如针对武力值的排名,老王这种战五渣肯定排名最后。

二、升序排列

升序,就是将数字最小的排前面,比如跑1000m的成绩,谁花时间少就排第一,所以这个时候别看老王数字最大,其实花的时间最长,又排到最后一名了。

注意RANK函数可以写第三参数哦,不写的时候是升序,写个1那就是升序了,不知道吧!

三、同名次按先后顺序

如果同样的数字,直接RANK排名的结果是一样,但是如果按照先后出现的顺序,老张那个战五渣出现在老王之后,那样老王我就不是和他同时排倒数第一了!

这里加上了一个COUNTIF函数,有兴趣的可以单独把COUNTIF拿出来看看,如果不太会,可以参考下面这篇文章。

四、组合排名

有时候排序的数据不在同一个区域,那该怎么做呢?做法不复杂,可是你大概没见过!

用了个括号将排名的参考区域组合起来了,嘿嘿嘿!

五、分组排名

有时候需要根据不同的组排名,毕竟老王这种小喽喽不能跟着大佬一起排名的!窝草!我还是和老张排倒数第一?我认了!

这里用RANK不能直接或者间接得到,所以用了迂回的方法,计算个数,嘿嘿!其实排名说到底不就是数个数嘛!

六、中国式排名

RANK排名在同一个名次的时候会占用后面的名次。比如示例二(降序时同样也占用名次)。中国式排名,要求同一个名次有多人时下一个名次是连续的。也就是下面这样。

这里是个数组公式,稍微有点复杂,有点数组基础的可以写写看!

七、分组中国式排名

分组排名有点复杂,中国式排名也很复杂,如果将两者组合起来,那岂不是更复杂,恭喜你,答对了!

这个我就不具体解释了,实在有点长,有兴趣的可以私聊我,虽然我会跟你解释但是你不一定能懂啊

一般来说,我们用不到后面的复杂情况,因为对于大多数人来说,写出函数的时间还不如排序然后手动排名来得实在,但是这些公式作为函数练习确实不错的材料!

当然最基础的降序升序用法,一定要会哦!

程序员网站