【问题标题】:Long/wide data to wide/long长/宽数据到宽/长
【发布时间】:2019-03-03 05:19:18
【问题描述】:

我有一个如下所示的数据框:

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],
    '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

也就是说,我正在寻找一种方法将“十进制”列从长格式更改为宽格式,同时将年份列从宽格式更改为长格式。我已经尝试过 pd.pivot_table、循环和 unstack,但没有任何运气。有什么聪明的方法可以解决这个问题吗?在此先感谢您的帮助。

【问题讨论】:

    标签: python pandas panel-data


    【解决方案1】:

    set_indexstackunstack 一起使用:

    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
    

    【讨论】:

    • 正是我正在寻找的!非常感谢。
    • 如果可行,则将其标记为答案,以便其他人可以看到它的答案!
    • 我会的。但似乎我只能在写完 10 分钟后才能接受它作为答案。
    • @AsbjørnKampJohannesen,谢谢 :-)
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-05-22
    • 2022-10-23
    • 2022-08-14
    • 2017-10-07
    • 2016-09-16
    • 1970-01-01
    相关资源
    最近更新 更多