ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 2005|回复: 5

[分享] 中国式排名(内存数组之二)

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-9-16 19:58 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 jacky1998 于 2014-9-19 11:54 编辑

1.jpg
中国式排名内存数组之二.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为最悲惨的排名公式,人多势众。
  1. =MMULT(N(A20:A29<=TRANSPOSE(A20:A29)),1/COUNTIF(A20:A29,A20:A29))
  2. =MMULT(N(A20:A29<=TRANSPOSE(A20:A29)),N(MATCH(A$20:A$29,A$20:A$29,)=ROW($1:$10)))
  3. =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)),)
  4. =MATCH(COUNTIF(A20:A29,">="&A20:A29),SMALL(IF(MATCH(A20:A29,A20:A29,)=ROW($1:$10),COUNTIF(A20:A29,">="&A20:A29)),ROW(1:10)),)
  5. =MATCH(A20:A29,LARGE(IF(FREQUENCY(A20:A29,A20:A29),A20:A29),ROW($1:$11)),)
  6. =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)
  7. =MMULT(1-ISNA(MATCH(RANK(A20:A29,A20:A29)-COLUMN(A:J)+1,RANK(A20:A29,A20:A29),)),ROW(1:10)^0)
  8. =MMULT(1-ISNA(MATCH(COUNTIF(A20:A29,">="&A20:A29)-COLUMN(A:J)+1,COUNTIF(A20:A29,">="&A20:A29),)),ROW(1:10)^0)
  9. =MATCH(A20:A29,LARGE(IF(MATCH(A20:A29,A20:A29,)=ROW(1:10),A20:A29),ROW(1:10)),)
  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

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-9-16 20:24 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-9-16 20:26 | 显示全部楼层
sw=andy 发表于 2014-9-16 20:24
传说中的沙发!!!!

不要客气,这里是沙滩,对面有好多美女。

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-11-14 18:40 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2014-11-14 22:23 | 显示全部楼层
本帖最后由 看见星光 于 2014-11-14 22:24 编辑

FREQNEUCY还有一个更加简练的统计中国式排名的方法,但现在还不能说。我等那道竞赛题,都等了一个月了,要被007憋死。
另外两个帖子,总结和分析写一下啊,该收网抓分啦。

TA的精华主题

TA的得分主题

发表于 2014-12-2 17:26 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-6-17 22:17 , Processed in 0.045980 second(s), 15 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表