从多索引数据帧中选择列,以生成直方图

2024-04-25 22:34:09 发布

您现在位置:Python中文网/ 问答频道 /正文

这是我第一次使用多索引数据帧。我有一个像这样的数据帧(小例子):

import random
col3=[0,0,0,0,2,4,6,0,0,0,100,200,300,400]
col4=[0,0,0,0,4,6,8,0,0,0,200,900,400, 500]

d = {'Unit': [1, 1, 1, 1, 2, 2, 2, 3, 4, 5, 6, 6, 6, 6], 
 'Year': [2014, 2015, 2016, 2017, 2015, 2016, 2017, 2017, 2014, 2015, 2014, 2015, 2016, 2017], 'col3' : col3, 'col4' : col4 }
df = pd.DataFrame(data=d)
df.groupby(['Unit', 'Year']).sum()

df = df.groupby(['Unit', 'Year']).sum()

df['mask'] = (df.groupby(level=0, group_keys=False)
                  .apply(lambda x: x.col3/x.col4.shift()))

df['mask'] = df['mask'].fillna(0) 

现在我想做一个柱状图,比如从mask列中的值,这不需要先做一个列表就可以了吗

我是这样做的:

values = [x for x in df['mask']]
plt.hist(values)

但我想最好不用中间列表步骤

谢谢你


Tags: 数据importdf列表unitmaskrandomyear