Próbuję użyć przycisków przełączania w Bokeh, aby utworzyć interaktywną witrynę internetową, w której użytkownik może kliknąć przyciski przełącznika, aby wybrać wykresy, które są nanoszone.ładowanie danych wykresu z plików kliknięciem przycisku z bokeh
Przyciski ładują dane z pliku tekstowego (zawierającego dwie kolumny danych xiy). pliki danych mają dwie kolumny zawierające dane x i y oddzielone spacją.
Po wybraniu przycisków przełączania zostaną narysowane odpowiednie dane, wykres zostanie usunięty, gdy przycisk przełącznika zostanie odznaczony.
Mam obecnie problem z przekazaniem argumentu do zdarzenia oddzwaniania, czy to możliwe?
from bokeh.io import vform
from bokeh.models import CustomJS, ColumnDataSource
from bokeh.models.widgets import Toggle
from bokeh.plotting import figure, output_file, show
output_file("load_data_buttons.html")
x = [0]
y = x
source = ColumnDataSource(data=dict(x=x, y=y))
plot = figure(plot_width=400, plot_height=400)
plot.line('x', 'y', source=source, line_width=3, line_alpha=0.6)
callback = CustomJS(args=filename,dict(source=source), code="""
var data = source.get('data');
console.log(filename)
x = data['x']
y = data['y']
#load data stored in the file name and assign to x and y
source.trigger('change');
""")
toggle1 = Toggle(label="Load data file 1", type="success",callback=callback("data_file_1.txt"))
toggle2 = Toggle(label="Load data file 2", type="success",callback=callback("data_file_2.txt"))
layout = vform(toggle1, toggle2, plot)
show(layout)
Dzięki za HYRY odpowiedzi. To jest naprawdę miłe, jedynym problemem jest to, że mam setki plików danych, które dają wiele MB danych. Naprawdę nie chcę tego z góry ładować, bo to zajmie dużo czasu. Czy znasz sposób na załadowanie danych po kliknięciu przycisków. – Jon
Następnie należy utworzyć funkcję javascript do parsowania pliku csv, tutaj jest przykład: http://stackoverflow.com/questions/7431268/how-to-read-data-from-csv-file-using-javascript – HYRY
Wielkie dzięki ta kombinacja odpowiedzi rozwiązała mój problem. Bardzo doceniane. – Jon