为了账号安全,请及时绑定邮箱和手机立即绑定

pandas多条件分组排序问题 row_number

pandas多条件分组排序问题 row_number

慕容3067478 2019-03-02 09:05:42
df = pd.DataFrame({'key1' : ['a','a','a','b','b'],    'key2' : ['c','d','c','c','d'],    'data' : [1,10,2,3,30]}) >>> df   key1 key2  data0    a    c     11    a    d    102    a    c     23    b    c     34    b    d    30目标结果 key1 key2  data  row_number0    a    c     1     11    a    d    10     12    a    c     2     23    b    c     3     14    b    d    30     1以key1、key2分组,按照data排序,取出序号应该怎么处理呢?搜索找到的以下方法没有成功df['row_number'] = df['data'].groupby(df['key1','key2']).rank(ascending=True,method='first')
查看完整描述

2 回答

?
杨__羊羊

TA贡献1943条经验 获得超7个赞

def cumsum_seq(v):    sub = v.sort_values('data')    sub['seq'] = sub['seq'].cumsum()    return sub.loc[:, ['data', 'seq']]

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


查看完整回答
反对 回复 2019-03-02
?
Smart猫小萌

TA贡献1911条经验 获得超7个赞


key1key2dataseq
0ac11
1ac22
2ad101
3bc31
4bd301


查看完整回答
反对 回复 2019-03-02
  • 2 回答
  • 0 关注
  • 1927 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号