我有一个熊猫数据框,例如:
In [61]: df = DataFrame(np.random.rand(3,4), index=['art','mcf','mesa'],
columns=['pol1','pol2','pol3','pol4'])
In [62]: df
Out[62]:
pol1 pol2 pol3 pol4
art 0.661592 0.479202 0.700451 0.345085
mcf 0.235517 0.665981 0.778774 0.610344
mesa 0.838396 0.035648 0.424047 0.866920
我想用跨基准策略的平均值生成一行,然后绘制它。
目前,我这样做的方式是:
df = df.T
df['average'] = df.apply(average, axis=1)
df = df.T
df.plot(kind='bar')
有没有一种优雅的方法来避免双重换位?
我试过:
df.append(DataFrame(df.apply(average)).T)
df.plot(kind='bar')
这将附加正确的值,但不会正确更新索引并且图表会混乱。
一个澄清。双转置的代码结果是这样的: 这就是我想要的。显示政策的基准和平均值,而不仅仅是平均值。我只是好奇我能不能做得更好。
请注意,图例通常是混乱的。修复:
ax = df.plot(kind='bar')
ax.legend(patches, list(df.columns), loc='best')