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

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

如何將多列旋轉為兩列,同時將列名和值都保留為python中的行條目

如何將多列旋轉為兩列,同時將列名和值都保留為python中的行條目

回首憶惘然 2022-10-25 09:42:14
我想轉換下表:id   name    2002   2003   20041    name1   1      2      32    name2   4      5      63    name3   7      8      9對此:id   name    year   value1    name1   2002   11    name1   2003   21    name1   2004   32    name2   2002   42    name2   2003   52    name2   2004   63    name3   2002   73    name3   2003   83    name3   2004   9我已經得到:df1.set_index(['id','name'])  .stack().reset_index(name='a')  .drop('a', 1)  .rename(columns={'level_2':'year'})這讓我得到了沒有值列的第二個表,我需要做什么來添加值列?
查看完整描述

1 回答

?
翻過高山走不出你

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

您可以使用pd.melt函數實現結果:

In [18]: df = df1.melt(id_vars=['id','name'],var_name='year',value_name='value')


In [19]: df

Out[19]:

   id   name  year  value

0   1  name1  2002      1

1   2  name2  2002      4

2   3  name3  2002      7

3   1  name1  2003      2

4   2  name2  2003      5

5   3  name3  2003      8

6   1  name1  2004      3

7   2  name2  2004      6

8   3  name3  2004      9


查看完整回答
反對 回復 2022-10-25
  • 1 回答
  • 0 關注
  • 103 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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