【问题标题】:Strange Labels on Bokeh Pie/Donut Chart散景饼图/甜甜圈图上的奇怪标签
【发布时间】:2019-12-12 06:04:42
【问题描述】:

我正在关注这个问题的回复:Adding labels in pie chart wedge in bokeh

我正在尝试向我的散景图表添加标签,以便用户可以查看数据值。由于某种原因,图表呈现如下:

我不确定为什么会这样。我尝试注释掉 z 变量,看看这是否有所作为。它没有。

这是我的代码:

import os
import pandas as pd
import pyodbc
from bokeh.plotting import figure, show
from bokeh.io import export_png
from bokeh.models import LabelSet, ColumnDataSource
from bokeh.palettes import Category20
import matplotlib as plt
from math import pi
from bokeh.transform import cumsum

lst = ['On_Time', 'All'] 

lst2 = [8, 85] 

df = pd.DataFrame(list(zip(lst, lst2)), 
               columns =['Column', 'Value']) 
df 

df['angle'] = df['value']/df['value'].sum() * 2*pi
df['angle']

df['color'] = ['#084594', '#2171b5']

#z=110*(df['value']/df['value'].sum())
#df['value']=z
#df

p = figure(plot_height=350, title="", toolbar_location=None,
           tools="", x_range=(-.5, .5))

p.annular_wedge(x=0, y=1,  inner_radius=0.15, outer_radius=0.25, direction="anticlock",
                start_angle=cumsum('angle', include_zero=True), end_angle=cumsum('angle'),
        line_color="white", fill_color='color', legend='column', source=df)

df["value"] = df['value'].astype(str)
df["value"] = df["value"].str.pad(35, side = "left")
source = ColumnDataSource(df)

labels = LabelSet(x=0, y=1, text='value', level='glyph',
        angle=cumsum('angle', include_zero=True), source=source, render_mode='canvas')

p.add_layout(labels)

p.axis.axis_label=None
p.axis.visible=False
p.grid.grid_line_color = None

show(p)

【问题讨论】:

  • 不是连接到您的数据库(没有人可以访问),而是重写问题以包含一个硬编码的数据框。
  • @PaulH 我刚刚添加了一个 sn-p 来显示数据框
  • 建议是让代码示例本身完整且可运行,以便其他人可以直接调查。
  • @bigreddot 明白了

标签: python pandas bokeh


【解决方案1】:

标签在“下方”,因为你已经设置了

level='glyph'

在对LabelSet 的调用中。干扰默认渲染级别的原因通常不是很多。如果您删除它,标签将按照 LabelSet 等注释的预期方式显示在“顶部”。

还要注意另一个答案用于定位标签对齐的“str padding”。这有点hacky但可以使用。观看者的浏览器之间的字体差异可能会产生微小的差异。另一种方法是计算您希望标签所在的圆圈周围的实际、精确的 x、y 位置。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-03-13
    • 1970-01-01
    • 1970-01-01
    • 2016-01-06
    • 2014-01-09
    相关资源
    最近更新 更多