为了账号安全,请及时绑定邮箱和手机立即绑定

如何在水平堆积条形图中显示精确的小数

如何在水平堆积条形图中显示精确的小数

慕斯王 2022-06-14 10:18:23
ntal_barchart_distribution.html 上找到了创建堆叠条形图的代码。问题是图中未显示小数位。在代码中,我发现列表中没有小数,但如果将它们更改为小数,则不会显示(参见下面的代码)。如果尝试将 str 更改为在 ax.text(x, y, str(int(c)) 行中浮动。这实际上显示小数,但它们都是 0。非常感谢。import numpy as npimport matplotlib.pyplot as pltcategory_names = ['Strongly disagree', 'Disagree','Neither agree nor   agree', 'agree', 'Strongly agree']results = {    'Question 1': [(10), (14.99), (17.01), (32), (26)]}def survey(results, category_names):    labels = list(results.keys())    data = np.array(list(results.values()))    data_cum = data.cumsum(axis=1)    category_colors = plt.get_cmap('RdYlGn')(        np.linspace(0.15, 0.85, data.shape[1]))    fig, ax = plt.subplots(figsize=(9.2, 5))    ax.invert_yaxis()    ax.xaxis.set_visible(False)    ax.set_xlim(0, np.sum(data, axis=1).max())    for i, (colname, color) in enumerate(zip(category_names, category_colors)):        widths = data[:, i]        starts = data_cum[:, i] - widths        ax.barh(labels, widths, left=starts, height=0.5,                label=colname, color=color)        xcenters = starts + widths / 2        r, g, b, _ = color        text_color = 'white' if r * g * b < 0.5 else 'darkgrey'        for y, (x, c) in enumerate(zip(xcenters, widths)):            ax.text(x, y, str(int(c)), ha='center', va='center',                color=text_color)    ax.legend(ncol=len(category_names), bbox_to_anchor=(0, 1),              loc='lower left', fontsize='small')    return fig, axsurvey(results, category_names)
查看完整描述

1 回答

?
jeck猫

TA贡献1909条经验 获得超7个赞

编写str(int(c))时,首先将数字转换为整数,从而去掉小数,然后将其转换为字符串。要获得所需的输出,请使用str(c),或者如果您希望能够更好地控制数字的格式(例如选择小数点后的位数),请替换str(int(c))为'{:.2f}'.format(c)


category_names = ['Strongly disagree', 'Disagree','Neither agree nor agree', 'agree', 'Strongly agree']


results = {

    'Question 1': [(10), (14.99), (17.01), (32), (26)]

}



def survey(results, category_names):

    labels = list(results.keys())

    data = np.array(list(results.values()))

    data_cum = data.cumsum(axis=1)

    category_colors = plt.get_cmap('RdYlGn')(

        np.linspace(0.15, 0.85, data.shape[1]))


    fig, ax = plt.subplots(figsize=(9.2, 5))

    ax.invert_yaxis()

    ax.xaxis.set_visible(False)

    ax.set_xlim(0, np.sum(data, axis=1).max())


    for i, (colname, color) in enumerate(zip(category_names, category_colors)):

        widths = data[:, i]

        starts = data_cum[:, i] - widths

        ax.barh(labels, widths, left=starts, height=0.5,

                label=colname, color=color)

        xcenters = starts + widths / 2


        r, g, b, _ = color

        text_color = 'white' if r * g * b < 0.5 else 'darkgrey'


        for y, (x, c) in enumerate(zip(xcenters, widths)):

            ax.text(x, y, '{:.2f}'.format(c), ha='center', va='center',

                color=text_color)

    ax.legend(ncol=len(category_names), bbox_to_anchor=(0, 1),

              loc='lower left', fontsize='small')


    return fig, ax



survey(results, category_names)


查看完整回答
反对 回复 2022-06-14
  • 1 回答
  • 0 关注
  • 106 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号