|Excel Developer Reference|
expression.Rank(Arg1, Arg2, Arg3)
expression A variable that represents a WorksheetFunction object.
|Arg1||Required||Double||Number - the number whose rank you want to find.|
|Arg2||Required||Range||Ref - an array of, or a reference to, a list of numbers. Nonnumeric values in ref are ignored.|
|Arg3||Optional||Variant||Order - a number specifying how to rank number.|
- If order is 0 (zero) or omitted, Microsoft Excel ranks number as if ref were a list sorted in descending order.
- If order is any nonzero value, Microsoft Excel ranks number as if ref were a list sorted in ascending order.
RANK gives duplicate numbers the same rank. However, the presence of duplicate numbers affects the ranks of subsequent numbers. For example, in a list of integers sorted in ascending order, if the number 10 appears twice and has a rank of 5, then 11 would have a rank of 7 (no number would have a rank of 6).
For some purposes one might want to use a definition of rank that takes ties into account. In the previous example, one would want a revised rank of 5.5 for the number 10. This can be done by adding the following correction factor to the value returned by RANK. This correction factor is appropriate both for the case where rank is computed in descending order (order = 0 or omitted) or ascending order (order = nonzero value).
Correction factor for tied ranks=[COUNT(ref) + 1 – RANK(number, ref, 0) – RANK(number, ref, 1)]/2.
In the following example, RANK(A2,A1:A5,1) equals 3. The correction factor is (5 + 1 – 2 – 3)/2 = 0.5 and the revised rank that takes ties into account is 3 + 0.5 = 3.5. If number occurs only once in ref, the correction factor will be 0, since RANK would not have to be adjusted for a tie.