javascript - Bokeh 单击按钮使用 javascript 将小部件值保存到 txt 文件

标签 javascript python bokeh

我想做这样的事情。我创建了一些小部件,例如下拉列表、多选框和文本输入框。然后我添加一个按钮。当用户选择小部件中的变量并单击按钮时。他们选择的值将作为 txt 文件下载。我希望这个 html 可以在没有 Bokeh 服务器的情况下使用,所以如果有人可以通过 customJS 完成它,我将不胜感激。

非常感谢。

from random import random
from bokeh.plotting import figure, output_file, show, ColumnDataSource
from bokeh.models import CustomJS, Button
from bokeh.layouts import row, column

savebutton = Button(label="Save", button_type="success")
savebutton.callback = CustomJS(args=dict(multi_select1.value,multi_select2.value), code="""
        var value1 = multi_select1.value;
        var value2 = multi_select1.value;

        var out = "";
        for (i = 0; i < value1.length; i++) {
            out += value1[i];
        }
        for (i = 0; i < value2.length; i++) {
            out += value2[i];
        }
        var file = new Blob([out], {type: 'text/plain'});
        var elem = window.document.createElement('a');
        elem.href = window.URL.createObjectURL(file);
        elem.download = 'selected-data.txt';
        document.body.appendChild(elem);
        elem.click();
        document.body.removeChild(elem);
        """)

assets=['asset1','asset2','asset3','asset4']
multi_select1 = MultiSelect(title="Select:", value=['asset1'],options=assets, height=200, width=100)
multi_select2 = MultiSelect(title="Select:", value=['asset1'],options=assets, height=200, width=100)

plot = column(multi_select1,multi_select2,savebutton)
show(plot)

最佳答案

好吧,看来我自己弄明白了。希望对其他人有帮助。

from bokeh.plotting import figure, output_file, show, ColumnDataSource
from bokeh.models import CustomJS, Button
from bokeh.layouts import row, column

x = ['asset1']
source= ColumnDataSource(data=dict(x=x))

callback = CustomJS(args=dict(source=source), code="""
    var data = source.data;
    var input = cb_obj.value;
    data['x']=input;
    source.change.emit();
""")

assets=['asset1','asset2','asset3','asset4']
multi_select1 = MultiSelect(title="Select:", value=['asset1'],options=assets, height=200, width=100)
multi_select1.js_on_change('value', callback)


savebutton = Button(label="Save", button_type="success")
savebutton.callback = CustomJS(args=dict(source=source), code="""
        var data = source.data;
        value1=data['x'];
        var out = "";
        for (i = 0; i < value1.length; i++) {
            out += value1[i];
        }
        var file = new Blob([out], {type: 'text/plain'});
        var elem = window.document.createElement('a');
        elem.href = window.URL.createObjectURL(file);
        elem.download = 'selected-data.txt';
        document.body.appendChild(elem);
        elem.click();
        document.body.removeChild(elem);
        """)


plot = column(multi_select1,savebutton)
show(plot)

关于javascript - Bokeh 单击按钮使用 javascript 将小部件值保存到 txt 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54215667/

相关文章:

javascript - jQuery-File-Upload - 一种形式的多个输入文件

javascript - Canvas 放置问题

python - 在两个不直接相关的小部件之间进行通信

python - 当tbody为空时如何隐藏thead?

python - 如何使用许多小文件加速 Spark Parquet Reader

python - Bokeh - 子类图

javascript - 为什么for-of-loop还没运行完,就跳出来运行console.log?

javascript - 将 CSS 应用于 iframe

python - 将 Bokeh 组件与 elementtree 结合使用

python - 如何使用 Python 的 Bokeh 向日期时间轴添加更多 x 轴刻度和标签?