Борьба с колбой + Bokeh AjaxDataSource:
У меня есть функция, которая возвращает данные json:
@app.route("/data", methods=['POST'])
def get_x():
global x, y
x = x + 0.1
y = math.sin(x)
return flask.jsonify(x=[x], y=[y])
Я могу использовать его с Bokeh AjaxDataSource без проблем для создания графика потоковой передачи:
source = AjaxDataSource(data_url="http://localhost:5000/data", polling_interval=1000, mode='append')
p = figure()
p.line('x', 'y', source=source)
show(p)
Однако, когда я пытаюсь встроить его в страницу флэшки, AjaxDataSource не запрашивает сервер. Сюжет не отображается без ошибок. Обратите внимание, что если я использую статический график вместо AjaxDataSource, он отлично подходит. Вот соответствующий код:
template = Template('''<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Streaming Example</title>
{{ js_resources }}
{{ css_resources }}
</head>
<body>
{{ plot_div }}
{{ plot_script }}
</body>
</html>
''')
@app.route("/")
def simple():
streaming=True
source = AjaxDataSource(data_url="http://localhost:5000/data",
polling_interval=1000, mode='append')
fig = figure(title="Streaming Example")
fig.line( 'x', 'y', source=source)
js_resources = INLINE.render_js()
css_resources = INLINE.render_css()
script, div = components(fig, INLINE)
html = template.render(
plot_script=script,
plot_div=div,
js_resources=js_resources,
css_resources=css_resources
)
return encode_utf8(html)
Если у кого-то есть мысли, я был бы благодарен.
Брайан