pandas多条件分组排序问题 row_number

发布于 2022-09-11 17:29:19 字数 593 浏览 13 评论 0

df = pd.DataFrame({'key1' : ['a','a','a','b','b'],
    'key2' : ['c','d','c','c','d'],
    'data' : [1,10,2,3,30]})

>>> df
  key1 key2  data
0    a    c     1
1    a    d    10
2    a    c     2
3    b    c     3
4    b    d    30

目标结果
key1 key2  data  row_number
0    a    c     1     1
1    a    d    10     1
2    a    c     2     2
3    b    c     3     1
4    b    d    30     1

以key1、key2分组,按照data排序,取出序号应该怎么处理呢?搜索找到的以下方法没有成功

df['row_number'] = df['data'].groupby(df['key1','key2']).rank(ascending=True,method='first')

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

捶死心动 2022-09-18 17:29:19
def cumsum_seq(v):
    sub = v.sort_values('data')
    sub['seq'] = sub['seq'].cumsum()
    return sub.loc[:, ['data', 'seq']]

df['seq'] = 1
df.groupby(['key1', 'key2']).apply(cumsum_seq).reset_index().drop(columns='level_2')

结果

key1key2dataseq
0ac11
1ac22
2ad101
3bc31
4bd301
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文