使用日期选择器更改轴范围

Changing Axis Range with Datepicker

我有一个在 x 轴上带有日期时间值的图,我想使用日期选择器小部件更改范围。但是 "cb_obj.value" 有一个问题,它不能直接用于 f.x_range.start 。 我找到了类似的,已解决。但是,我从回调对象 adjust/convert 我的值仍然有很多麻烦,特别是因为这必须在 Java 中完成。或者,我错了吗?

import numpy as np
from bokeh.models import CustomJS, DatePicker, TextInput, ColumnDataSource
from bokeh.layouts import row, layout
from bokeh.plotting import output_file, show, figure
from datetime import datetime, timedelta

output_file("DatePicker.html")

# Figure
f=figure(x_axis_type='datetime')

# Datetime
date_time = [datetime(2017,1,1) + timedelta(days=x) for x in range(0,365)]

# ColumnDataSource
source = ColumnDataSource(dict(datetime=date_time, parameter=np.random.rand(365)))

# Line for plot
f.line(x='datetime',y='parameter',line_color='black',source=source)

# Callback
callbackPlot= CustomJS(args=dict(f=f), code="""
    var a = cb_obj.value;
    f.x_range.start = a;
""")

# Datepicker
DatepickerPlot = DatePicker(
    title="Start:", name="StartDate",  value=date_time[0])
DatepickerPlot.js_on_change('value', callbackPlot)

# Show 
show(layout(row(DatepickerPlot, f)))

除此之外,是否有另一种方法可以在不使用 CustomJS/Java 的情况下使用回调在 Bokeh 中制作独立的 HTML 文件?

cb_obj.value是一个字符串,而f.x_range.start需要一个数字,改成

f.x_range.start = a;

f.x_range.start = Date.parse(a);