使用 pandas 交叉表创建条形图
问题描述
我正在尝试使用我的数据框在海运中创建堆叠条形图。
我首先在 pandas 中生成了一个交叉表,如下所示:
pd.crosstab(df['Period'], df['Mark'])
返回:
Mark False True
Period BASELINE 583 132
WEEK 12 721 0
WEEK 24 589 132
WEEK 4 721 0
我想使用海运为全余创建一个堆叠的条形图,这就是我在我的图表的睡觉中使用的。但是,我很难做到这一点,因为我无法为交叉表编制索引。
我已经能够使用.plot.barh(stacked=True)
在 pandas 身上制作我想要的情节,但在海运方面没有运气。你知道我该怎么做吗?
解决方案
- 如您所说,您可以使用 pandas 创建堆叠条形图。您想要有一个海运绘图的论点是无关紧要的,因为每个海运绘图和每个 pandas 绘图最终都只是matplotlib对象,因为这两个库的绘图工具仅仅是matplotlib包装器。
- 这里有一个完整的解决方案(使用@Andrew_Reess的答案创建数据)。
- 测试于
python 3.8.11
、pandas 1.3.2
、matplotlib 3.4.3
、seaborn 0.11.2
import numpy as np
import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt
n = 500
np.random.seed(365)
mark = np.random.choice([True, False], n)
periods = np.random.choice(['BASELINE', 'WEEK 12', 'WEEK 24', 'WEEK 4'], n)
df = pd.DataFrame({'mark': mark, 'period': periods})
ct = pd.crosstab(df.period, df.mark)
ax = ct.plot(kind='bar', stacked=True, rot=0)
ax.legend(title='mark', bbox_to_anchor=(1, 1.02), loc='upper left')
# add annotations if desired
for c in ax.containers:
# set the bar label
ax.bar_label(c, label_type='center')
相关文章