简体   繁体   English

MatPlotLib:如何在堆积条形图的每个条形上显示总和标签?

[英]MatPlotLib: How to show sum labels on each bar for a stacked bar chart?

I am graphing the following stacked bar chart using matplotlib, and I would like to show the total views (of the entire bar) on top of each stacked bar.我正在使用 matplotlib 绘制以下堆积条形图,并且我想在每个堆积条形图的顶部显示(整个条形图的)总视图。 This is the code I am using to create the graph:这是我用来创建图形的代码:

okrViews = okrs_results['Page Views'].tolist()
blogViews = blog_results['Page Views'].tolist()
landingPageViews = landing_page_results['Page Views'].tolist()
teamsViews = teams_results['Page Views'].tolist()
eventsViews = events_results['Page Views'].tolist()
initiativesViews = initiatives_results['Page Views'].tolist()
toolsViews = tools_results['Page Views'].tolist()
indx = np.arange(len(months))

# Calculate starting position for each bar
okrsAndBlogs = [i+j for i,j in zip(okrViews, blogViews)]
okrsBlogsLanding = [i+j for i,j in zip(landingPageViews, okrsAndBlogs)]
four = [i+j for i,j in zip(teamsViews, okrsBlogsLanding)]
five = [i+j for i,j in zip(eventsViews, four)]
six = [i+j for i,j in zip(initiativesViews, five)]

# Set figure size
plt.figure(figsize=(19,10))

# Add each bar
graphBlogs = plt.bar(x = indx, height = blogViews, width = .45, color='tab:blue', label = 'Blogs')
graphOkrs = plt.bar(x = indx, height = okrViews, width = .45, color='tab:pink', bottom = blogViews, label = 'OKRs')
graphLanding = plt.bar(x = indx, height = landingPageViews, width = .45, color='green', bottom = okrsAndBlogs, label = 'Landing Page')
graphTeams = plt.bar(x = indx, height = teamsViews, width = .45, color='orange', bottom = okrsBlogsLanding, label = 'Teams')
graphEvents = plt.bar(x = indx, height = eventsViews, width = .45, color='tab:olive', bottom = four, label = 'Events')
graphInitiatives = plt.bar(x = indx, height = initiativesViews, width = .45, color='tab:purple', bottom = five, label = 'Initiatives; Risk and Data Privacy')
graphTools = plt.bar(x = indx, height = toolsViews, width = .45, color='tab:cyan', bottom = six, label = 'Tools')

    
# Set labels
plt.xticks(indx, months)
plt.xlabel("Month")
plt.ylabel("Total Views")
plt.title('Views per Day, Grouped by Month, YTD')
plt.legend()

plt.show()

How would I go about doing this?我该怎么做呢? To explain further, I'd like to have ~10,000 above January's stacked bar, ~8,000 above Februarys, and so on.为了进一步解释,我希望比 1 月的堆积柱高约 10,000,比 2 月的堆积柱高约 8,000,依此类推。 Thanks in advance!提前致谢!

当前图表

Update: Figured it out, I just had to sum it up manually, then I used plt.text .更新:想通了,我只需要手动总结,然后我使用plt.text In a prior cell, I had initialized months to be a list of the names of the months.在之前的单元格中,我将months初始化为months名称列表。

Solution:解决方案:

monthTotals = []
for month in months:
    total = 0
    total += int(okrs_results[okrs_results['Month'] == month]['Page Views'])
    total += int(blog_results[blog_results['Month'] == month]['Page Views'])
    total += int(landing_page_results[landing_page_results['Month'] == month]['Page Views'])
    total += int(teams_results[teams_results['Month'] == month]['Page Views'])
    total += int(events_results[events_results['Month'] == month]['Page Views'])
    total += int(initiatives_results[initiatives_results['Month'] == month]['Page Views'])
    total += int(tools_results[initiatives_results['Month'] == month]['Page Views'])
    monthTotals.append(total)

okrViews = okrs_results['Page Views'].tolist()
blogViews = blog_results['Page Views'].tolist()
landingPageViews = landing_page_results['Page Views'].tolist()
teamsViews = teams_results['Page Views'].tolist()
eventsViews = events_results['Page Views'].tolist()
initiativesViews = initiatives_results['Page Views'].tolist()
toolsViews = tools_results['Page Views'].tolist()
indx = np.arange(len(months))

# Calculate starting position for each bar
okrsAndBlogs = [i+j for i,j in zip(okrViews, blogViews)]
okrsBlogsLanding = [i+j for i,j in zip(landingPageViews, okrsAndBlogs)]
four = [i+j for i,j in zip(teamsViews, okrsBlogsLanding)]
five = [i+j for i,j in zip(eventsViews, four)]
six = [i+j for i,j in zip(initiativesViews, five)]

# Set figure size
plt.figure(figsize=(19,10))

# Add each bar
graphBlogs = plt.bar(x = indx, height = blogViews, width = .45, color='tab:blue', label = 'Blogs')
graphOkrs = plt.bar(x = indx, height = okrViews, width = .45, color='tab:pink', bottom = blogViews, label = 'OKRs')
graphLanding = plt.bar(x = indx, height = landingPageViews, width = .45, color='green', bottom = okrsAndBlogs, label = 'Landing Page')
graphTeams = plt.bar(x = indx, height = teamsViews, width = .45, color='orange', bottom = okrsBlogsLanding, label = 'Teams')
graphEvents = plt.bar(x = indx, height = eventsViews, width = .45, color='tab:olive', bottom = four, label = 'Events')
graphInitiatives = plt.bar(x = indx, height = initiativesViews, width = .45, color='tab:purple', bottom = five, label = 'Initiatives; Risk and Data Privacy')
graphTools = plt.bar(x = indx, height = toolsViews, width = .45, color='tab:cyan', bottom = six, label = 'Tools')

# Show sum on each stacked bar
for i, v in enumerate(monthTotals):
    if v != 0:
        plt.text(indx[i] - .2, v, str(v))
    
# Set labels
plt.xticks(indx, months)
plt.xlabel("Month")
plt.ylabel("Total Views")
plt.title('Views per Day, Grouped by Month, YTD')
plt.legend()

plt.show()

Result:结果:

解决方案

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM