2

pivot_table の列の再配置について質問があります。列を月ごとにグループ化したいのですが、次のように配置します。

JAN      FEB  
X,Y,X/Y  X,Y,X/Y ....

現在の出力は次のとおりです。

JAN FEB      JAN  FEB    JAN ...

X   X   ...  Y     Y ...  X/Y ...

複数の列を持つピボット テーブルを作成するときに、Excel で実装されたのと同じ動作に気付きました。

以下の例を参照してください。出力には最初の形式があります。ありがとう

from pandas import DataFrame,pivot_table
import numpy as np
from datetime import datetime 

names=["a","b","c","a","b"]
dates=["20/01/2013","21/01/2013","22/02/2013", "01/03/2013","01/03/2013"]
dico={"x":[1,3,5,7,9], "y":[2,4,6,8,10], "date":dates, "name":names}

df=DataFrame(dico)
df["month"]=[datetime.strptime(x,'%d/%m/%Y').month for x in dates ]

print df
mpivot=pivot_table(df, values=["x","y"],cols=["month"], rows="name",aggfunc=np.sum)
print mpivot
4

1 に答える 1

4

このピボット テーブルが作成されたら、これを行うことができます。

In [11]: p = pivot_table(df, values=["x","y"], cols=["month"], 
                             rows="name", aggfunc=np.sum)

In [12]: p
Out[12]:
        x           y
month   1   2   3   1   2   3
name
a       1 NaN   7   2 NaN   8
b       3 NaN   9   4 NaN  10
c     NaN   5 NaN NaN   6 NaN

最初に列レベルを切り替えてから、列並べ替えます

In [13]: p.reorder_levels([1, 0], axis=1).sort_index(axis=1)
Out[13]:
month   1       2       3
        x   y   x   y   x   y
name
a       1   2 NaN NaN   7   8
b       3   4 NaN NaN   9  10
c     NaN NaN   5   6 NaN NaN
于 2013-06-20T09:21:03.590 に答える