<i id='6jLbo'><tr id='6jLbo'><dt id='6jLbo'><q id='6jLbo'><span id='6jLbo'><b id='6jLbo'><form id='6jLbo'><ins id='6jLbo'></ins><ul id='6jLbo'></ul><sub id='6jLbo'></sub></form><legend id='6jLbo'></legend><bdo id='6jLbo'><pre id='6jLbo'><center id='6jLbo'></center></pre></bdo></b><th id='6jLbo'></th></span></q></dt></tr></i><div id='6jLbo'><tfoot id='6jLbo'></tfoot><dl id='6jLbo'><fieldset id='6jLbo'></fieldset></dl></div>
  • <small id='6jLbo'></small><noframes id='6jLbo'>

    <tfoot id='6jLbo'></tfoot>

  • <legend id='6jLbo'><style id='6jLbo'><dir id='6jLbo'><q id='6jLbo'></q></dir></style></legend>

        • <bdo id='6jLbo'></bdo><ul id='6jLbo'></ul>
      1. 如何在分组条形图上方显示百分比

        时间:2023-09-14

        <i id='5iYwK'><tr id='5iYwK'><dt id='5iYwK'><q id='5iYwK'><span id='5iYwK'><b id='5iYwK'><form id='5iYwK'><ins id='5iYwK'></ins><ul id='5iYwK'></ul><sub id='5iYwK'></sub></form><legend id='5iYwK'></legend><bdo id='5iYwK'><pre id='5iYwK'><center id='5iYwK'></center></pre></bdo></b><th id='5iYwK'></th></span></q></dt></tr></i><div id='5iYwK'><tfoot id='5iYwK'></tfoot><dl id='5iYwK'><fieldset id='5iYwK'></fieldset></dl></div>
        • <bdo id='5iYwK'></bdo><ul id='5iYwK'></ul>

            <tfoot id='5iYwK'></tfoot>
          1. <legend id='5iYwK'><style id='5iYwK'><dir id='5iYwK'><q id='5iYwK'></q></dir></style></legend>

            <small id='5iYwK'></small><noframes id='5iYwK'>

                    <tbody id='5iYwK'></tbody>

                1. 本文介绍了如何在分组条形图上方显示百分比的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                  问题描述

                  以下是 pandas 数据框和由此生成的条形图:

                  colors_list = ['#5cb85c','#5bc0de','#d9534f']result.plot(kind='bar',figsize=(15,4),width = 0.8,color = colors_list,edgecolor=None)plt.legend(labels=result.columns,fontsize=14)plt.title("受访者对数据科学领域感兴趣的百分比",fontsize= 16)plt.xticks(字体大小=14)对于 plt.gca().spines.values() 中的脊椎:脊柱.set_visible(假)plt.yticks([])

                  我需要在相应栏上方显示各个主题的每个兴趣类别的百分比.我可以创建一个包含百分比的列表,但我不明白如何将它添加到相应栏的顶部.

                  解决方案

                  尝试将以下 for 循环添加到您的代码中:

                  ax = result.plot(kind='bar', figsize=(15,4), width=0.8, color=colors_list, edgecolor=None)对于 ax.patches 中的 p:宽度 = p.get_width()高度 = p.get_height()x, y = p.get_xy()ax.annotate(f'{height}', (x + width/2, y + height*1.02), ha='center')


                  说明

                  通常,您使用

                  The following are the pandas dataframe and the bar chart generated from it:

                  colors_list = ['#5cb85c','#5bc0de','#d9534f']
                  result.plot(kind='bar',figsize=(15,4),width = 0.8,color = colors_list,edgecolor=None)
                  plt.legend(labels=result.columns,fontsize= 14)
                  plt.title("Percentage of Respondents' Interest in Data Science Areas",fontsize= 16)
                  
                  plt.xticks(fontsize=14)
                  for spine in plt.gca().spines.values():
                      spine.set_visible(False)
                  plt.yticks([])
                  

                  I need to display the percentages of each interest category for the respective subject above their corresponding bar. I can create a list with the percentages, but I don't understand how to add it on top of the corresponding bar.

                  解决方案

                  Try adding the following for loop to your code:

                  ax = result.plot(kind='bar', figsize=(15,4), width=0.8, color=colors_list, edgecolor=None)
                  
                  for p in ax.patches:
                      width = p.get_width()
                      height = p.get_height()
                      x, y = p.get_xy() 
                      ax.annotate(f'{height}', (x + width/2, y + height*1.02), ha='center')
                  


                  Explanation

                  In general, you use Axes.annotate to add annotations to your plots.
                  This method takes the text value of the annotation and the xy coords on which to place the annotation.

                  In a barplot, each "bar" is represented by a patch.Rectangle and each of these rectangles has the attributes width, height and the xy coords of the lower left corner of the rectangle, all of which can be obtained with the methods patch.get_width, patch.get_height and patch.get_xy respectively.

                  Putting this all together, the solution is to loop through each patch in your Axes, and set the annotation text to be the height of that patch, with an appropriate xy position that's just above the centre of the patch - calculated from it's height, width and xy coords.


                  For your specific need to annotate with the percentages, I would first normalize your DataFrame and plot that instead.

                  colors_list = ['#5cb85c','#5bc0de','#d9534f']
                  
                  # Normalize result
                  result_pct = result.div(result.sum(1), axis=0)
                  
                  ax = result_pct.plot(kind='bar',figsize=(15,4),width = 0.8,color = colors_list,edgecolor=None)
                  plt.legend(labels=result.columns,fontsize= 14)
                  plt.title("Percentage of Respondents' Interest in Data Science Areas",fontsize= 16)
                  
                  plt.xticks(fontsize=14)
                  for spine in plt.gca().spines.values():
                      spine.set_visible(False)
                  plt.yticks([])
                  
                  # Add this loop to add the annotations
                  for p in ax.patches:
                      width = p.get_width()
                      height = p.get_height()
                      x, y = p.get_xy() 
                      ax.annotate(f'{height:.0%}', (x + width/2, y + height*1.02), ha='center')
                  

                  这篇关于如何在分组条形图上方显示百分比的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                  上一篇:Matplotlib:以图像为注释的 3D 散点图 下一篇:在 Python 3.6 中运行时根据联合类型检查变量

                  相关文章

                  最新文章

                  1. <tfoot id='EUytP'></tfoot>

                        <bdo id='EUytP'></bdo><ul id='EUytP'></ul>
                      <legend id='EUytP'><style id='EUytP'><dir id='EUytP'><q id='EUytP'></q></dir></style></legend>

                      <small id='EUytP'></small><noframes id='EUytP'>

                      <i id='EUytP'><tr id='EUytP'><dt id='EUytP'><q id='EUytP'><span id='EUytP'><b id='EUytP'><form id='EUytP'><ins id='EUytP'></ins><ul id='EUytP'></ul><sub id='EUytP'></sub></form><legend id='EUytP'></legend><bdo id='EUytP'><pre id='EUytP'><center id='EUytP'></center></pre></bdo></b><th id='EUytP'></th></span></q></dt></tr></i><div id='EUytP'><tfoot id='EUytP'></tfoot><dl id='EUytP'><fieldset id='EUytP'></fieldset></dl></div>