您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 长/宽数据到宽/长

5b51 2022/1/14 8:23:12 python 字数 1813 阅读 565 来源 www.jb51.cc/python

我有一个数据框,如下所示: import pandas as pd d = {'decil': ['1. decil','1. decil','2. decil','2. decil','3. decil','3. decil'], 'kommune': ['AA','BB','AA','BB','AA','BB'],'2010':[44,25,242,423,845,962],

概述

import pandas as pd
d = {'decil': ['1. decil','1. decil','2. decil','3. decil','3. decil'],'kommune': ['AA','BB','AA','BB'],'2010':[44,25,242,423,845,962],'2011':[64,26,239,620,862,862]}    
df = pd.DataFrame(data=d)

印花

decil      kommune  2010  2011
1. decil   AA       44    64
1. decil   BB       25    26
2. decil   AA      242   239
2. decil   BB      423   620
3. decil   AA      845   862
3. decil   BB      962   862

我想要的输出是这样的

kommune  year  1. decil  2. decil  3. decil
 AA       2010        44       242       845
 AA       2011        64       239       862
 BB       2010        25       423       962
 BB       2011        25       620       862

也就是说,我正在寻找一种方法将’decil’列从长格式更改为宽格式,同时将年份列从宽格式更改为长格式.我已经尝试了pd.pivot_table,循环和unstack没有任何运气.这有什么聪明的方法吗?提前,谢谢你的帮助.

df = (df.set_index(['decil','kommune'])
        .stack()
        .unstack(0)
        .reset_index()
        .rename_axis(None,axis=1))

print (df)
  kommune level_1  1. decil  2. decil  3. decil
0      AA    2010        44       242       845
1      AA    2011        64       239       862
2      BB    2010        25       423       962
3      BB    2011        26       620       862

总结

以上是编程之家为你收集整理的python – 长/宽数据到宽/长全部内容,希望文章能够帮你解决python – 长/宽数据到宽/长所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶