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

Plotly:如何向直方图添加文本标签?

Plotly:如何向直方图添加文本标签?

杨__羊羊 2023-08-15 18:52:52
有没有办法在 Plotly.Express 直方图中显示直方图聚合的计数值?px.histogram(pd.DataFrame({"A":[1,1,1,2,2,3,3,3,4,4,4,5]}),x="A")如果我使用常规直方图,我可以指定text直接指向包含要显示的值的列的参数。px.bar(pd.DataFrame({"val":[1,2,3,4,5], "height": [3,2,3,3,1]}), x="val", y="height", text="height")但对于直方图,该值是计算出来的,它甚至不是fig.to_dict(). 有没有办法将文本标签添加到直方图中?使用下面的答案,我将这一发现总结为一篇文章 - https://towardsdatascience.com/histograms-with-plotly-express-complete-guide-d483656c5ad7
查看完整描述

3 回答

?
阿晨1998

TA贡献2037条经验 获得超6个赞

text_auto设置为的参数将True执行您想要的操作。

以您的示例代码为例,这就是我得到的:

fig = px.histogram(pd.DataFrame({"A":[1,1,1,2,2,3,3,3,4,4,4,5]}),x="A", 
text_auto=True)
fig.show()


查看完整回答
反对 回复 2023-08-15
?
白板的微信

TA贡献1883条经验 获得超3个赞

据我所知,绘图直方图没有文本属性。事实证明,如果可能的话,检索应用的 x 和 y 值并将它们放入适当的注释中也是很复杂的。您最好的选择似乎是使用numpy.histogram处理分箱并使用go.Bar. 下面的代码片段将产生以下图:


https://img2.sycdn.imooc.com/64db595500017e1f05800366.jpg

完整代码:

import numpy as np

import plotly.express as px

import plotly.graph_objects as go


# sample data

df = px.data.tips()


# create bins

bins = [0, 10, 20, 30, 40, 50]

counts, bins = np.histogram(df.total_bill, bins=bins)

#bins2 = 0.5 * (bins1[:-1] + bins2[1:])


fig = go.Figure(go.Bar(x=bins, y=counts))

fig.data[0].text = counts

fig.update_traces(textposition='inside', textfont_size=8)

fig.update_layout(bargap=0)



fig.update_traces(marker_color='blue', marker_line_color='blue',

                  marker_line_width=1, opacity=0.4)


fig.show()


查看完整回答
反对 回复 2023-08-15
?
MM们

TA贡献1886条经验 获得超2个赞

今天早上我在尝试绘制 TDD 百分比直方图时遇到了同样的问题。我想使用plotly 进行标准化(histnorm:“百分比”),这样我就可以看到每月 TDD 值的百分比而不是计数。我通过简单地执行print(tdd_hist)找到了这个解决方案


首先,我将直方图打印到控制台并看到这个输出......


Figure({

'data': [{'alignmentgroup': 'True',

          'bingroup': 'x',

          'histnorm': 'percent',

          'hovertemplate': 'Total Demand Distortion TDD %=%{x}<br>count=%{y}<extra></extra>',

          'legendgroup': '',

          'marker': {'color': '#636efa'},

          'name': '',

          'offsetgroup': '',

          'orientation': 'v',

          'showlegend': False,

          'type': 'histogram',

          'x': array([0.67, 0.68, 0.68, ..., 2.41, 2.48, 2.01]),

          'xaxis': 'x',

          'yaxis': 'y'}],

'layout': {'barmode': 'relative',

           'legend': {'tracegroupgap': 0},

           'template': '...',

           'title': {'text': 'Percent Histogram of TDD%'},

           'xaxis': {'anchor': 'y', 'domain': [0.0, 1.0], 'title': {'text': 'Total Demand Distortion TDD %'}},

           'yaxis': {'anchor': 'x', 'domain': [0.0, 1.0], 'title': {'text': 'count'}, 'type': 'log'}}

现在我可以清楚地看到,为了改变这一点,我做了一个


tdd_hist.layout.yaxis.title.text = 'Percent'


查看完整回答
反对 回复 2023-08-15
  • 3 回答
  • 0 关注
  • 200 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信