散景等值线图不会随滑块而变化

问题描述 投票:0回答:1

想为自己创造一个散景等值线。它显示中国被多边形分割成它的Provinces,用一个名为surplus的值着色。我从1995年到2016年有Years,我正在尝试使用滑块更新颜色。我的数据框看起来像这样(10的随机样本):

     Year   Province       Surplus
371  2014      Hubei  5.953000e+06
268  1999     Fujian  7.123000e+06
44   1995      Hebei  9.030000e+05
246  1999      Anhui  1.300600e+07
236  2011   Zhejiang -5.258105e+06
406  2005  Guangdong  1.117000e+07
180  1999   Shanghai  1.543000e+06
252  2005      Anhui  1.250800e+07
346  2011      Henan -1.538884e+05
399  1998  Guangdong  1.614100e+07

我的代码是这样的:

source = ColumnDataSource(data = df_all)

color_mapper = LinearColorMapper(palette = Spectral6, 
                                 low = df_all.Surplus.min(),
                                 high = df_all.Surplus.max())

p = figure(title = 'Statistics by Year',
           plot_height = 700,
           plot_width = 1100)

p.patches('x', 'y', 
          source = source, 
          fill_color = {'field': 'Surplus', 
                        'transform': color_mapper},
          line_color = 'black',
          line_width = 0.60,    
          fill_alpha = 0.60)

def callback(attr, old, new):
    yr = slider.value
    new_data = df_all[df_all.Year == yr]
    source.data = new_data

slider = Slider(start = 1995, 
                end = 2016, 
                value = 1995, step = 1, 
                title = "Year")
slider.on_change('value', callback)

hover = HoverTool(tooltips = [('Province','@Province'), ('Surplus', '@Surplus')])

color_bar = ColorBar(color_mapper = color_mapper, width=8,  location=(0,0))
layout = column(widgetbox(slider), p)
curdoc().add_root(layout)

outfp = r"C:\Users\myname\surplus2016.html"
save(p, outfp)

但是,我的颜色不随着我的滑块移动,我不知道为什么。可能与我的更新步骤有关。有任何想法吗?我已经成功地获得了合唱。

python data-visualization bokeh choropleth
1个回答
0
投票

当您使用show将代码作为“常规”python脚本运行时,您将创建一个仅存在于浏览器中的独立HTML输出,而不与任何Python进程连接。在这种情况下,不可能运行真正的Python回调,因为浏览器根本不了解Python。在回调中运行真正的Python代码,即使用on_change,需要将代码作为Bokeh server application运行:

  • show替换curdoc().add_root(p)电话,和
  • bokeh serve --show <filename>运行代码
© www.soinside.com 2019 - 2024. All rights reserved.