Bokeh:将vars传递给CustomJS for Widgets

时间:2015-08-31 19:51:21

标签: javascript python ipython-notebook bokeh

关于Bokeh的一个好处是,可以从Python层指定回调,该回调可以在javascript级别上执行操作,而无需使用bokeh-server。因此,可以创建在浏览器中运行的交互式小部件,而无需运行Ipython或Bokeh服务器。

0.9.3。文档提供了一个我可以在ipython笔记本中重现的示例: http://bokeh.pydata.org/en/latest/docs/user_guide/interaction.html#cutomjs-for-widgets

from bokeh.io import vform
from bokeh.models import CustomJS, ColumnDataSource, Slider
from bokeh.plotting import figure, output_file, show

output_file("callback.html")
x = [x*0.005 for x in range(0, 200)]
y = x

source = ColumnDataSource(data=dict(x=x, y=y))

plot = figure(plot_width=400, plot_height=400)
plot.line('x', 'y', source=source, line_width=3, line_alpha=0.6)

callback = CustomJS(args=dict(source=source), code="""
        var data = source.get('data');
        var f = cb_obj.get('value')
        x = data['x']
        y = data['y']
        for (i = 0; i < x.length; i++) {
            y[i] = Math.pow(x[i], f)
        }
        source.trigger('change');
    """)

slider = Slider(start=0.1, end=4, value=1, step=.1, title="power", callback=callback)

layout = vform(slider, plot)
show(layout)

我想调整这样的代码来创建一些简单的在线作业。我的问题是如何在不调用Slider的情况下直接将其他变量从python传递到javascript。例如,假设我希望Javascript成为:

y[i] = Math.pow(x[i], A*f)

其中A是在上面的ipython代码单元格中定义的(例如A = 10)。在javascript中定义'var A = 10'很容易,但是我想在python中设置A和其他变量的值,然后将它们传递给这个javascript。有办法吗?

1 个答案:

答案 0 :(得分:5)

截至Bokeh 0.9.3,您只能通过&#34; Bokeh模型&#34; (例如数据源和渲染器之类的东西),而不是任意的python对象。但我们正在努力扩展散景文档,使用简单的命名空间概念,可以轻松地进行镜像。