如何与条形图一起显示百分比

How to display percentage along with bar chart

我已经为下面的数据绘制了条形图

                Total Monthly Actual Hours  Total Monthly Work Hours
Activity Month
Apr-19          35381.25                    42592
May-19          31722.50                    44528
Jun-19          27708.50                    38720
Jul-19          34283.50                    44528
Aug-19          21359.90                    42592

.

到目前为止我的代码

display(dfWorkActual)

dfWorkActual.plot(kind='bar')
plt.ylabel('Work Hours')
plt.xlabel('Month')
plt.title("Total Monthly Work Hours & Total Actual Work Hours vs Month")

现在我想添加总实际小时数占每月总小时数的百分比。

例如:

请指教

你可以做的就是用这种方式在绘图上注释一些文本

for x,y,tex in zip(x_axis, abs_value, perc_value):
        t = ax.text(x, 
                    y, 
                    f"{tex:.2f} %", 
                    horizontalalignment='center',
                    verticalalignment='center',
                    size = 11.5, 
                    bbox = dict(boxstyle="round", 
                                fc="w", 
                                ec='#414141', 
                                linewidth=1.4))

其中 x_axis 是一个包含列所在点的列表。 abs_value 是包含列高的列表,perc_value 是包含百分比的列表。 我在文本中放置了一些其他元素,例如 bbox 将创建一个圆角白框,其中包含百分比。尝试使用参数以获得最适合您的目的。 如您所见,我将文本 f"{tex:.2f} %" 放置在坐标 (x, y) 处。 希望对你有帮助。

要注释条形图,您可以在此处参考 matplotlib 文档中的示例。

https://matplotlib.org/3.1.1/gallery/lines_bars_and_markers/barchart.html#sphx-glr-gallery-lines-bars-and-markers-barchart-py

fig = plt.figure(figsize=(15,10))
ax = plt.gca()
width = 0.35
rects1 = ax.bar(df.index-width/2, df.A, width)
rects2 = ax.bar(df.index+width/2, df.B, width)
for r1, r2 in zip(rects1, rects2):
    h1 = r1.get_height()
    h2 = r2.get_height()
    percent = int(h1 * 100 / h2)
    ax.annotate('{}%'.format(percent),
                    xy=(r1.get_x() + r1.get_width() / 2, h1),
                    xytext=(0, 3),  # 3 points vertical offset
                    textcoords="offset points",
                    ha='center', va='bottom')
    ax.annotate('100%',
                    xy=(r2.get_x() + r2.get_width() / 2, h2),
                    xytext=(0, 3),  # 3 points vertical offset
                    textcoords="offset points",
                    ha='center', va='bottom')

plt.show()

fig = plt.figure(figsize=(15,10))
ax = plt.gca()
width = 0.35
rects1 = ax.bar(df.index, df.A, width)
rects2 = ax.bar(df.index, df.B, width, bottom=df.A)
for r1, r2 in zip(rects1, rects2):
    h1 = r1.get_height()
    h2 = r2.get_height()
    percent = int(h1 * 100 / h2)
    ax.annotate('{}%'.format(percent),
                    xy=(r1.get_x() + r1.get_width() / 2, h1/2),
                    xytext=(0, 0),
                    textcoords="offset points",
                    ha='center', va='bottom')
    ax.annotate('100%',
                    xy=(r2.get_x() + r2.get_width() / 2, h1+h2/2),
                    xytext=(0, 0), 
                    textcoords="offset points",
                    ha='center', va='bottom')

plt.show()