Excel 保持原序时计算组内排名

Excel某表格第1列是分组,第2列是日期,未排序。

|----|----------|--------------|
| | A | B |
| 1 | Agent ID | Date of Sale |
| 2 | Agent1 | 07-12-2023 |
| 3 | Agent1 | 05-12-2023 |
| 4 | Agent2 | 09-12-2023 |
| 5 | Agent3 | 13-12-2023 |
| 6 | Agent2 | 14-12-2023 |
| 7 | Agent2 | 22-12-2023 |
| 8 | Agent1 | 15-12-2023 |
| 9 | Agent1 | 17-12-2023 |
| 10 | Agent2 | 13-12-2023 |
| 11 | Agent1 | 20-12-2023 |
| 12 | Agent1 | 18-12-2023 |
| 13 | Agent3 | 20-12-2023 |
| 14 | Agent3 | 09-12-2023 |

要求在保持原序的情况下,算出每组数据的内部排名,写在第3列:

|----|----------|--------------|--------|
| | A | B | C |
| 1 | Agent ID | Date of Sale | result |
| 2 | Agent1 | 07-12-2023 | 2 |
| 3 | Agent1 | 05-12-2023 | 1 |
| 4 | Agent2 | 09-12-2023 | 1 |
| 5 | Agent3 | 13-12-2023 | 2 |
| 6 | Agent2 | 14-12-2023 | 3 |
| 7 | Agent2 | 22-12-2023 | 4 |
| 8 | Agent1 | 15-12-2023 | 3 |
| 9 | Agent1 | 17-12-2023 | 4 |
| 10 | Agent2 | 13-12-2023 | 2 |
| 11 | Agent1 | 20-12-2023 | 6 |
| 12 | Agent1 | 18-12-2023 | 5 |
| 13 | Agent3 | 20-12-2023 | 3 |
| 14 | Agent3 | 09-12-2023 | 1 |

使用 SPL XLL

复制代码
=spl("=E(?).derive(#:id,rk).sort(#1,#2).run(rk=rank(#2;#1)).sort(id).(rk)",A1:B14)

函数 E 将片区转为表格,derive 增加新列,rank 计算排序后的组内记录的排名,# 是行号,#1 是第 1 列。

免费下载试用

相关推荐
<但凡.6 分钟前
C++修炼:string类的使用
开发语言·c++·算法
helbyYoung10 分钟前
【零基础JavaScript入门 | Day7】三大交互案例深度解析|从DOM操作到组件化开发
开发语言·javascript
小张-森林人1 小时前
C#中,什么是委托,什么是事件及它们之间的关系
开发语言·c#
何似在人间5751 小时前
JAVA实现动态IP黑名单过滤
java·开发语言·tcp/ip·nacos·黑名单过滤
demonlg01121 小时前
Go 语言标准库中log模块详细功能介绍与示例
开发语言·后端·云原生·golang
努力学习的小廉2 小时前
【C++】 —— 笔试刷题day_9
开发语言·c++·代理模式
Yhame.2 小时前
【 C 语言实现顺序表的基本操作】(数据结构)
c语言·开发语言·数据结构
eqwaak02 小时前
京东商品爬虫技术解析:基于Selenium的自动化数据采集实战
开发语言·人工智能·爬虫·python·selenium·自动化
速盾cdn2 小时前
速盾:Python可以用高防CDN吗?
开发语言·网络·python
Min_小明2 小时前
CMake 简单使用总结
android·开发语言·算法