如果在 Bokeh DataTable 中引用行/列的 JS 代码出错,可能是以下几个原因导致的:
代码中的引用名称错误:确保你在 JS 代码中正确地引用了行和列的名称。可以通过查看 DataTable 的源代码来确认列的名称。
代码中的语法错误:检查 JS 代码中是否存在语法错误,例如拼写错误、缺少分号等。可以使用浏览器的开发者工具或 JS 编辑器来帮助查找错误。
下面是一个示例解决方法,以在 Bokeh DataTable 中引用列的 JS 代码为例:
from bokeh.models import DataTable, ColumnDataSource, NumberFormatter, StringFormatter
# 创建一个示例的数据源
data = {'column1': [1, 2, 3], 'column2': ['A', 'B', 'C']}
source = ColumnDataSource(data)
# 创建 DataTable 并使用 ColumnDataSource
table = DataTable(source=source, columns=[
TableColumn(field='column1', title='Column 1', formatter=NumberFormatter(format='0')),
TableColumn(field='column2', title='Column 2', formatter=StringFormatter(font_style='bold'))
])
# 在 JS 代码中引用列
table.js_on_change('value', CustomJS(args=dict(source=source), code="""
// 获取当前选中行的数据
var selected_row = source.selected.indices[0];
var column1_value = source.data['column1'][selected_row];
var column2_value = source.data['column2'][selected_row];
// 在控制台中打印值
console.log('Column 1 value:', column1_value);
console.log('Column 2 value:', column2_value);
"""))
在上面的示例中,我们创建了一个 DataTable,并使用 ColumnDataSource 进行数据绑定。然后,我们通过 js_on_change
方法添加了一个 JS 回调函数,该回调函数在 DataTable 的选中行更改时触发。在回调函数中,我们使用了 source.selected.indices[0]
来获取当前选中行的索引,并使用 source.data['column1'][selected_row]
和 source.data['column2'][selected_row]
来获取选中行的列值。最后,我们通过 console.log
将这些值打印到控制台中。
请注意,此示例中的 JS 代码是在 Bokeh 服务器端运行的,因此你需要在 Bokeh 服务器上运行应用程序才能看到 JS 控制台输出。