如何在excel中使用rank函数排序

如题所述

第1个回答  2010-05-01
RANK

请参阅

返回一个数字在数字列表中的排位。数字的排位是其大小与列表中其他值的比值(如果列表已排过序,则数字的排位就是它当前的位置)。

语法

RANK(number,ref,order)

Number 为需要找到排位的数字。

Ref 为数字列表数组或对数字列表的引用。Ref 中的非数值型参数将被忽略。

Order 为一数字,指明排位的方式。

如果 order 为 0(零)或省略,Microsoft Excel 对数字的排位是基于 ref 为按照降序排列的列表。
如果 order 不为零,Microsoft Excel 对数字的排位是基于 ref 为按照升序排列的列表。
说明

函数 RANK 对重复数的排位相同。但重复数的存在将影响后续数值的排位。例如,在一列按升序排列的整数中,如果整数 10 出现两次,其排位为 5,则 11 的排位为 7(没有排位为 6 的数值)。

由于某些原因,用户可能使用考虑重复数字的排位定义。在前面的示例中,用户可能要将整数 10 的排位改为 5.5。这可通过将下列修正因素添加到按排位返回的值来实现。该修正因素对于按照升序计算排位(顺序 = 非零值)或按照降序计算排位(顺序 = 0 或被忽略)的情况都是正确的。

重复数排位的修正因素 =[COUNT(ref) + 1 – RANK(number, ref, 0) – RANK(number, ref, 1)]/2。

在下列示例中,RANK(A2,A1:A5,1) 等于 3。修正因素是 (5 + 1 – 2 – 3)/2 = 0.5,考虑重复数排位的修改排位是 3 + 0.5 = 3.5。如果数字仅在 ref 出现一次,由于不必调整 RANK,因此修正因素为 0。

示例

如果您将示例复制到空白工作表中,可能会更易于理解该示例。

操作方法

创建空白工作簿或工作表。
请在“帮助”主题中选取示例。不要选取行或列标题。

从帮助中选取示例。

按 Ctrl+C。
在工作表中,选中单元格 A1,再按 Ctrl+V。
若要在查看结果和查看返回结果的公式之间切换,请按 Ctrl+`(重音符),或在“工具”菜单上,指向“公式审核”,再单击“公式审核模式”。

1
2
3
4
5
6
A
数据
7
3.5
3.5
1
2
公式 说明(结果)
=RANK(A3,A2:A6,1) 3.5 在上表中的排位 (3)
=RANK(A2,A2:A6,1) 7 在上表中的排位 (5)

祝你成功!
第2个回答  2019-11-16

rank是T_sql 函数,rank()函数返回结果集分区内指定字段的值的排名,指定字段的值的排名是相关行之前的排名加一。具体使用步骤如下:

1、在excel中编辑好需要排序的内容。

2、在C2单元格输入公式“=RANK(B2,$B$2:$B$4,0)”。

3、点击键盘“Enter”。

4、双击图示符号,向下填充公式。

5、公式填充后,排名结果就出来了。

注意事项:

1、操作第二步,在C2单元格输入公式“=RANK(B2,$B$2:$B$4,0)”时,引用单元格时必须是绝对引用“$B$2:$B$4”,否则在向下填充公式时会出现错误。

2、操作第二步,在C2单元格输入公式“=RANK(B2,$B$2:$B$4,0)”时,排位方式输入“0”是降序排列,若需要升序排列输入“1”即可。

扩展资料:

语法:

RANK() OVER([<partiton_by_clause>]<order by clause>)

partition_by_clause 将from子句生成的结果集划分为应用到RANK函数的分区。

Order_by_clause确定将RANK值应用到分区中的行时所使用的顺序。

以下用一个成绩表作示例:

table架构:

s_score(s_class(班级),s_id(学号),s_score(分数))。

SQL statement1:

Select rank() over(order by s_score desc) as 名次,s_class,s_id,s_score from s_score。

参考资料来源:

第3个回答  2019-11-13

首先,打开需要修改的Exce,然后选择需要修改的数据,输入rank公式即可排序。具体步骤如下:

1、电脑打开Excel表格。

2、电脑打开Excel表格后,在排名中输入公式=RANK(J11,$J$11:J$14),$J$11:J$14是所有成绩单元格的绝对值,选中单元格后按F4就会变成绝对值。

3、输入公式后,就会得到名次,下拉复制公式。

4、所有排名就都出来了。

注意事项:

1、复制的单元格含公式或链接太多,复制粘贴时计算量较大导致计算机卡死。

2、选择复制的区域太大,因为部分数据不能体现,导致系统计算更加复杂容易卡死。

第4个回答  2015-06-19

rank(参数1,参数2,参数3)

参数1,包含在参数2内,参数3忽略或0为升序,不为0为降序

另外,新版本的Excel还有Rank的变形可以更好的处理排名问题。

=RANK(A3,$A$3:$A$12,)

=RANK.AVG(A3,$A$3:$A$12,)

=RANK.EQ(A3,$A$3:$A$12,)

第5个回答  2016-05-27
方法/步骤
1
平常生活中,我们想将一列数字排序,大家最易想到的是用排序按钮,然后下一列用自动填充功能填充,但是当遇到两个数据相同的时候,这样填充出来的数据就不能很好的显示排名情况。如下图所示,两个105相同的分数,但是自动填充显示的名次却不一样。我们还得对这些相同分数的排名进行手动修改。

2
如何让EXCEL帮助我们,不用排序快捷键,而且能去除重名次呢。首先我们不用将数据排序,回到最初数据形式。如下图所示:

3
下面我们需要运用RANK函数。在B2单元格中输入以下内容:=RANK(A2,$A$2:$A$24)。其中A2是需要确定位次的数据,$A$2:$A$24表示数据范围,括号里的内容即表示A2单元格数据在A2:A24这个数据区域的排名情况,公式计算结果将被显示在B2单元格里。下图1为公式,下图2为计算结果的显示。

4
然后选中B2单元格,将鼠标放在右下角,鼠标变成小十字的时候,按下鼠标左键不放,往下拉到B24单元格,这样所有分数的排名就显示出来了。如下图所示:

END
注意事项
注意:在输入数据范围的时候,一定要用 $符号,否则排出来的名次会是错误的。

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网