悬停工具在散景中不起作用[重复]

Posted

技术标签:

【中文标题】悬停工具在散景中不起作用[重复]【英文标题】:Hover tool not working in Bokeh [duplicate] 【发布时间】:2017-02-08 12:37:58 【问题描述】:

我有一个表格,其中包含学生访问活动的次数。

  df_act5236920.head()

    activities  studs
 0  3.0       student 1
 1  4.0       student 10
 2  5.0       student 11
 3  6.0       student 12
 4  2.0       student 13
 5  4.0       student 14
 6  19.0      student 15

如果我尝试通过以下代码将悬停工具添加到此数据框创建的条形图中:

 from bokeh.charts import Bar
 from bokeh.models import Legend

 from collections import OrderedDict
 TOOLS = "pan,wheel_zoom,box_zoom,reset,hover,save"
 bar = Bar(df_act5236920,values='activities',label='studs',title = "Activity 5236920 performed by students",
      xlabel="Students",ylabel="Activity",legend=False,tools=TOOLS)
 hover = bar.select_one(HoverTool)
 hover.point_policy = "follow_mouse"
 hover.tooltips = OrderedDict([
     ("Student Name", "@studs"),
     ("Access Count", "@activities"),
 ])
 show(bar)

当我将鼠标悬停在条形图上时,它显示的是学生值而不是活动值,我什至尝试使用“$activities”但结果还是一样。

根据我阅读的其他堆栈溢出问题,我尝试使用 ColumnDataSource 而不是 DataFrame,如下面的代码所示:

source = ColumnDataSource(ColumnDataSource.from_df(df_act5236920))

from collections import OrderedDict
TOOLS = "pan,wheel_zoom,box_zoom,reset,hover,save"
bar = Bar('studs','activities',source=source, title = "Activity 5236920 performed by students",tools=TOOLS)
hover = bar.select_one(HoverTool)
hover.point_policy = "follow_mouse"
hover.tooltips = OrderedDict([
    ("Student Name", "@studs"),
    ("Access Count", "@activities"),
])
show(bar)

它给了我以下错误:

    ---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-76-81505464c390> in <module>()
  3 # bar = Bar(df_act5236920,values='activities',label='studs',title = "Activity 5236920 performed by students",
  4 # xlabel="Students",ylabel="Activity",legend=False,tools=TOOLS)
  ----> 5 bar = Bar('studs','activities',source=source, title = "Activity 5236920 performed by students",tools=TOOLS)
  6 hover = bar.select_one(HoverTool)
  7 hover.point_policy = "follow_mouse"

C:\Anaconda2\lib\site-packages\bokeh\charts\builders\bar_builder.pyc in  Bar(data, label, values, color, stack, group, agg, xscale, yscale, xgrid, ygrid, continuous_range, **kw)
319     kw['y_range'] = y_range
320 
--> 321     chart = create_and_build(BarBuilder, data, **kw)
322 
323     # hide x labels if there is a single value, implying stacking only

C:\Anaconda2\lib\site-packages\bokeh\charts\builder.pyc in create_and_build(builder_class, *data, **kws)
 66     # create the new builder
 67     builder_kws = k: v for k, v in kws.items() if k in builder_props
---> 68     builder = builder_class(*data, **builder_kws)
 69 
 70     # create a chart to return, since there isn't one already

C:\Anaconda2\lib\site-packages\bokeh\charts\builder.pyc in __init__(self, *args, **kws)
292             # make sure that the builder dimensions have access to the chart data source
293             for dim in self.dimensions:
--> 294                 getattr(getattr(self, dim), 'set_data')(data)
295 
296             # handle input attrs and ensure attrs have access to data

C:\Anaconda2\lib\site-packages\bokeh\charts\properties.pyc in set_data(self, data)
170             data (`ChartDataSource`): the data source associated with the chart
171         """
--> 172         self.selection = data[self.name]
173         self._chart_source = data
174         self._data = data.df

TypeError: 'NoneType' object has no attribute '__getitem__'

我什至尝试通过以值列表的形式将数据框的列传递给它,从头开始创建 ColumnDataSource,但我仍然遇到与上面显示的错误相同的错误

source = ColumnDataSource(data=dict(
     studs=students,
     activities=activity_5236920,
))

当我尝试在热图上实现悬停工具时,我也遇到了同样的问题。谁能帮忙解决这个问题?

【问题讨论】:

Try source = ColumnDataSource(df_act5236920) from_df() 在 Bokeh 0.9.3 中已被弃用。可能值得一试 @BobHaffner 我试过了,但错误还是一样。源对象也是使用我提到的其他两个实现创建的。我假设它们可能是空的,这就是它抛出 NoneType 错误的原因,但我不知道为什么它是空的。 好的。关于错误,我认为您的来源很好。只是Bar() 需要一个数据源作为第一个参数,而您正在传递一个字符串 Try bar = Bar(df_act5236920,label='studs', values='activities',source=source, title = "Activity 5236920 performed by students",tools=TOOLS)。没有关于您的工具提示问题的线索。祝你好运 @BobHaffnerjust 看到了您的答案,我同时添加了我自己的答案以及相同的分辨率,并且也部分解决了工具提示问题。感谢您的帮助。 【参考方案1】:

所以,在浏览了很多文档之后,我终于弄清楚了一些事情。

首先,NoneType 错误是由于对于条形图,您需要传递数据框以及 ColumnDataSource 才能显示条形图。 所以代码需要是:

bar = Bar(df_act5236920,values='activities',label='studs',title = "Activity 5236920 performed by students",
      xlabel="Students",ylabel="Activity",legend=False,tools=TOOLS,source=source)

注意数据框名称和 source=source 在 Bar() 方法中是如何被提及的。 对于不显示值的第二个问题,我使用了@height,它实质上显示了所选条的高度,在本例中是计数值。

hover.tooltips = OrderedDict([
   ("Student Name", "@studs"),
   ("Access Count", "@height"),
]) 

对于学生姓名值,@x 和 @studs 都有效。但我仍然无法解决的唯一问题是,虽然我提到了 ColumnDataSource “源”,但它并没有真正为我完成任何事情,因为当我尝试在 hover.tooltips 中使用 @activities 时,它仍然给了我一个响应的 ”???”。所以,我不确定那是什么。这是我在尝试构建的另一个时间序列可视化中遇到的一个问题。

【讨论】:

以上是关于悬停工具在散景中不起作用[重复]的主要内容,如果未能解决你的问题,请参考以下文章

在散景中悬停多行字形时如何显示单个值?

元素上的悬停效果在 CSS 中不起作用 [重复]

CSS列表悬停在Google Chrome中不起作用[重复]

:悬停在按钮的跨度上在 IE 中不起作用

如何在散景中绘制纬度和经度

背景图像过渡在CSS中不起作用[重复]