亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

pandas多條件分組排序問題 row_number

pandas多條件分組排序問題 row_number

嗶嗶one 2019-02-17 04:19:36
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')
查看完整描述

1 回答

?
德瑪西亞99

TA貢獻1770條經驗 獲得超3個贊

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')

結果

key1 key2 data seq
0 a c 1 1
1 a c 2 2
2 a d 10 1
3 b c 3 1
4 b d 30 1
查看完整回答
反對 回復 2019-03-01
  • 1 回答
  • 0 關注
  • 491 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號