我正在尝试使用Bokeh制作可编辑的DataTable,以便在编辑数据时更新源数据.我从标准的DataTable示例here开始,并将可编辑的kwarg设置为true.这是我在的地方:
from datetime import date
from random import randint
from bokeh.models import ColumnDataSource, Callback
from bokeh.models.widgets import DataTable, DateFormatter, TableColumn
from bokeh.io import output_file, output_notebook, show, vform
output_notebook()
data = dict(dates=[date(2014, 3, i+1) for i in range(10)],
downloads=[randint(0, 100) for i in range(10)])
source = ColumnDataSource(data)
columns = [TableColumn(field="dates", title="Date", formatter=DateFormatter()),
TableColumn(field="downloads", title="Downloads")]
callback = Callback(args=dict(Source=source), code="""
console.log( '#cell edited')""")
data_table = DataTable(source=source, columns=columns, width=400, height=280, editable=True)
data_table.on_change(callback,source)
show(vform(data_table))
这使得一个可编辑的数据表,但我无法弄清楚如何获取回调来更新源数据,或配置源数据,以便它自动执行该操作.我认为有一种方法可以使用ColumnDataSource自动执行此操作,并在尝试尝试编写回调之后.但是看起来DataTable没有回调选项,但奇怪的是它有一个on_change属性.
有谁知道如何做到这一点?
解决方法:
以下代码将检测单击(选择)一行或多行的事件.我放了一些console.log来输出所选的行.
from datetime import date
from random import randint
import bokeh
import bokeh.plotting
data = dict(dates=[date(2014, 3, i+1) for i in range(10)],
downloads=[randint(0, 100) for i in range(10)])
source = bokeh.models.ColumnDataSource(data)
columns = [bokeh.models.TableColumn(field="dates", title="Date",
formatter=bokeh.models.DateFormatter()),
bokeh.models.TableColumn(field="downloads", title="Downloads")]
source.callback = bokeh.models.CustomJS(args=dict(source=source), code="""
console.log( '#Selected rows:');
var indices = source.selected["1d"].indices;
for (var i = 0; i<indices.length; i++){
console.log(i+":"+indices[i]);
}
""")
data_table = bokeh.models.DataTable(source=source, columns=columns,
width=400, height=280, editable=True)
bokeh.io.output_notebook()
bokeh.io.show(data_table)
标签:python,python-2-7,bokeh 来源: https://codeday.me/bug/20191004/1852750.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。