|
本帖最后由 jacky1998 于 2014-9-19 11:54 编辑
中国式排名内存数组之二.rar
(4.65 KB, 下载次数: 121)
实况:
请注意,1,2,4,6,8可对文本进行公式(文本比大小的结果正确性有待确认),
比如你在A20:A29输入=MID("9主席万岁幸会啦朋友",ROW(1:10),1)
其它的限于数字排名。如果你找数字文本混杂的排名,那我只能说声抱歉啦(也许第8式可以文本数字分别排名,但有BUG)。
第1,2式中,文本排名高于数字。第7式文本排在最后且无各自名次。
第3,5式中,如果原列文本数字混杂,结果全部出错。
第10式为投机排名,遇混杂时,结果为数字,但全部不对。
总结:
第1,2,5,9为最常用的排名方式。
第7,8为不走寻常路(适用于N条件中国式排名)
第3,4,6为最悲惨的排名公式,人多势众。
- =MMULT(N(A20:A29<=TRANSPOSE(A20:A29)),1/COUNTIF(A20:A29,A20:A29))
- =MMULT(N(A20:A29<=TRANSPOSE(A20:A29)),N(MATCH(A$20:A$29,A$20:A$29,)=ROW($1:$10)))
- =MATCH(RANK(A20:A29,A20:A29),SMALL(IF(MATCH(A$20:A$29,A$20:A$29,)=ROW($1:$10),RANK(A20:A29,A20:A29)),ROW(1:10)),)
- =MATCH(COUNTIF(A20:A29,">="&A20:A29),SMALL(IF(MATCH(A20:A29,A20:A29,)=ROW($1:$10),COUNTIF(A20:A29,">="&A20:A29)),ROW(1:10)),)
- =MATCH(A20:A29,LARGE(IF(FREQUENCY(A20:A29,A20:A29),A20:A29),ROW($1:$11)),)
- =MMULT(1-ISNA(MATCH(ROW($1:$10)%+COLUMN($A:$J),SMALL(($A20:$A29>=TRANSPOSE($A20:$A29))*MATCH(A20:A29,A20:A29,)+COLUMN(A:J)%,ROW($1:$100)),)),ROW($1:$10)^0)
- =MMULT(1-ISNA(MATCH(RANK(A20:A29,A20:A29)-COLUMN(A:J)+1,RANK(A20:A29,A20:A29),)),ROW(1:10)^0)
- =MMULT(1-ISNA(MATCH(COUNTIF(A20:A29,">="&A20:A29)-COLUMN(A:J)+1,COUNTIF(A20:A29,">="&A20:A29),)),ROW(1:10)^0)
- =MATCH(A20:A29,LARGE(IF(MATCH(A20:A29,A20:A29,)=ROW(1:10),A20:A29),ROW(1:10)),)
- =MMULT(1-ISNA(MATCH(A20:A29+COLUMN(A:GS)-1,A20:A29,)),ROW(1:201)^0)
复制代码
补充内容 (2014-9-25 14:43):
分开排名公式优化:
=SUM((A$20:A$29>=A20)/COUNTIF(A$20:A$29,A$20:A$29))
=SUM(--IF(FREQUENCY(A$20:A$29,A$20:A$29),A$20:A$29>=A20))
补充内容 (2014-9-27 21:55):
内存数组11式=RANK(A20:A29,A20:A29)-MMULT(-(RANK(A20:A29,A20:A29)>COLUMN($A:$K)),-(FREQUENCY(RANK(A20:A29,A20:A29),ROW(1:10))>1)) |
评分
-
8
查看全部评分
-
|