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

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

Python pandas 如何將 df :列值轉置為行值?

Python pandas 如何將 df :列值轉置為行值?

HUH函數 2023-06-27 13:09:30
原始 df:df=pd.DataFrame({'name':['id1','id1','id2','id2','id2'],             'attr1':['a','b','c','d','e']})    Out[45]:   name attr10  id1     a1  id1     b2  id2     c3  id2     d4  id2     e我想要的是:系統需要更多詳細信息,但我無話可說,所以請不要在這里查看這些文字,這會浪費您的時間。
查看完整描述

2 回答

?
明月笑刀無情

TA貢獻1828條經驗 獲得超4個贊

讓我們嘗試cumcount使用附加鍵進行分配


s = df.assign(key=df.groupby('name').cumcount()+1).pivot('name','key','attr1')


s

Out[125]: 

key   1  2    3

name           

id1   a  b  NaN

id2   c  d    e


查看完整回答
反對 回復 2023-06-27
?
慕神8447489

TA貢獻1780條經驗 獲得超1個贊

做就是了

  1. 按列分組

  2. 添加 lambda 聚合函數

  3. 拆分為列。

df.groupby('name') .agg(lambda x: '|'.join(x)) .attr1.str.split('|',expand=True)

將以上三者結合起來

>> df.groupby('name').agg(lambda x: '|'.join(x)).attr1.str.split('|',expand=True)


      0  1     2

name            

id1   a  b  None

id2   c  d     e


查看完整回答
反對 回復 2023-06-27
  • 2 回答
  • 0 關注
  • 184 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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