python 堆叠柱状图 dataframe_使用DataFrame.p在堆叠条形图中显示总计和百分比

您可以使用plt.text根据您的数据将信息放置在各个位置。

然而,如果你有非常小的酒吧,它可能需要一些调整,以看起来完美。df_total = df['Total Cost']

df = df.iloc[:, 0:4]

df.plot(x = 'Airport', kind='barh',stacked = True, title = 'Breakdown of Costs', mark_right = True)

df_rel = df[df.columns[1:]].div(df_total, 0)*100

for n in df_rel:

for i, (cs, ab, pc, tot) in enumerate(zip(df.iloc[:, 1:].cumsum(1)[n], df[n], df_rel[n], df_total)):

plt.text(tot, i, str(tot), va='center')

plt.text(cs - ab/2, i, str(np.round(pc, 1)) + '%', va='center', ha='center')

编辑:为了更好的可读性,一些武断的想法:

将总值向右移动,使用45°旋转文本:plt.text(tot+10000, i, str(tot), va='center')

plt.text(cs - ab/2, i, str(np.round(pc, 1)) + '%', va='center', ha='center', rotation=45)

在上下对齐文本之间切换:va = ['top', 'bottom']

va_idx = 0

for n in df_rel:

va_idx = 1 - va_idx

for i, (cs, ab, pc, tot) in enumerate(zip(df.iloc[:, 1:].cumsum(1)[n], df[n], df_rel[n], df_total)):

plt.text(tot+10000, i, str(tot), va='center')

plt.text(cs - ab/2, i, str(np.round(pc, 1)) + '%', va=va[va_idx], ha='center')

仅标记10%或以上的条形图:if pc >= 10:

plt.text(cs - ab/2, i, str(np.round(pc, 1)) + '%', va='center', ha='center')

…或仍然打印,但垂直:if pc >= 10:

plt.text(cs - ab/2, i, str(np.round(pc, 1)) + '%', va='center', ha='center')

else:

plt.text(cs - ab/2, i, str(np.round(pc, 1)) + '%', va='center', ha='center', rotation=90)

你可能感兴趣的:(python,堆叠柱状图,dataframe)