Create a plot from a pandas dataframe pivot table(从 pandas 数据帧数据透视表创建绘图)
本文介绍了从 pandas 数据帧数据透视表创建绘图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我是Python新手,想知道如何在我使用数据透视表函数创建的数据上创建条形图。
#Create a pivot table for handicaps count calculation for no-show people based on their gender
pv = pd.pivot_table(df_main, values=['hipertension','diabetes','alcoholism'],
columns='status',index='gender',aggfunc=np.sum)
#Reshape the pivot table for easier calculation
data_pv = pv.unstack().unstack('status').reset_index().rename(columns={'level_0':'category','No-Show':'no_show', 'Show-Up':'show_up'})
data_pv['no_show_prop'] = (data_pv['no_show']/
(data_pv['no_show']+data_pv['show_up']))*100
data_pv
因此:
status category gender no_show show_up no_show_prop
0 alcoholism F 308 915 25.183974
1 alcoholism M 369 1768 17.267197
2 diabetes F 1017 4589 18.141277
3 diabetes M 413 1924 17.672229
4 hipertension F 2657 12682 17.321859
5 hipertension M 1115 5347 17.254720
我想创建一个条形图,类别为x轴,no_show_prop为y轴,每个类别有两个不同颜色的条形图,分别表示雌性和雄性。我也试过使用Groupby,但结果不是我想要的那样。
我希望创建一个类别为x轴、no_show_prop为y轴的条形图,而不是下图中的条形图,其中有两个不同颜色的条形图,分别表示每个类别的男性和女性。我也试过使用Groupby,但结果不是我想要的那样。推荐答案
从data_pv
开始,使用pandas.Dataframe.pivot
或pandas.DataFrame.pivot_table
将数据重塑为较宽的形式,pandas.DataFrame.plot
更容易绘制,它将使用索引作为x轴,将列作为条形值。
pivot_table
如果值需要聚合(例如'sum'
)pivot
如果不需要聚合
使用kind='bar'
绘制条形图,或使用kind='line'
绘制折线图。两者都可以工作,具体取决于所需的绘图。
df = data_pv.pivot(index='category', columns='gender', values='no_show_prop')
df
现在看起来如下:
gender F M
category
alcoholism 25.183974 17.267197
diabetes 18.141277 17.672229
hipertension 17.321859 17.254720
然后您可以简单地执行以下操作:
df.plot(kind='bar')
这篇关于从 pandas 数据帧数据透视表创建绘图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:从 pandas 数据帧数据透视表创建绘图
猜你喜欢
- python check_output 失败,退出状态为 1,但 Popen 适用于相同的命令 2022-01-01
- pytorch 中的自适应池是如何工作的? 2022-07-12
- 如何在 python3 中将 OrderedDict 转换为常规字典 2022-01-01
- 如何将一个类的函数分成多个文件? 2022-01-01
- 沿轴计算直方图 2022-01-01
- 使用Heroku上托管的Selenium登录Instagram时,找不到元素';用户名'; 2022-01-01
- 分析异常:路径不存在:dbfs:/databricks/python/lib/python3.7/site-packages/sampleFolder/data; 2022-01-01
- python-m http.server 443--使用SSL? 2022-01-01
- 如何在 Python 的元组列表中对每个元组中的第一个值求和? 2022-01-01
- padding='same' 转换为 PyTorch padding=# 2022-01-01