Я хочу создать веб-интерфейс с python srcipt, чтобы генерировать различные графики из множества CSV.
Для этого я использую pandas, графически ave c ipywidgets в качестве библиотек и Jupyter Notebook.
Мой первый скрипт позволяет отображать CSV в соответствии с сервером и датой, выбранной в выпадающие списки:
from ipywidgets import interact, Dropdown
from ipywidgets import widgets
from IPython.display import display
import plotly.express as px
import pandas as pd
from ipywidgets.embed import embed_minimal_html
import sys
import os
###################### Déclarations des widgets ######################
button = widgets.ToggleButton(description='click me')
out = widgets.Output(layout=widgets.Layout(border = '1px solid black'))
Server = os.listdir('/home/tim/Bureau/Servers/')
ServerList = widgets.Dropdown(options = (Server))
Date = ['2019-10', '2019-11', '2019-12', '2020-01']
DateList = widgets.Dropdown(options = (Date))
@interact(ServersList = Server, DatesList = Date)
def print_all(ServersList, DatesList):
Test = os.listdir('/home/tim/Bureau/Servers'+ '/'+ ServersList+ '/'+ DatesList+'/')
Path = os.path.join('/home/tim/Bureau/Servers'+ '/'+ ServersList+ '/'+ DatesList+'/' + str(Test).strip("[]").strip("''"))
display(Path)
df = pd.read_csv(Path)
df.head()
fig = px.line(df, x = 'Date', y = 'Total', title='DF command graph')
fig.add_scatter(mode='markers+lines')
display(df)
Этот скрипт работает отлично, вывод:
Мой второй скрипт позволяет отображать CSV и отслеживать график согласно FS выберите в раскрывающемся списке. Сценарий:
import ipywidgets as widgets
from ipywidgets import interactive
import pandas as pd
import plotly.graph_objects as go
import plotly.express as px
df = pd.read_csv('/home/tim/Bureau/Servers/Server1/2019-10/Test1.txt')
items = ['All']+sorted(df['FS'].unique().tolist())
def view(x=''):
if x=='All': display(df)
display(df[df['FS']==x])
fig = px.line(df[df['FS']==x], x = 'Date', y ='Total', title='DF command graph')
#fig.add_scatter(x=df['Date'], y=df['Used'])
fig.update_traces(mode='markers+lines')
fig.show();
w = widgets.Dropdown(options=items)
interactive(view, x=w)
Этот сценарий тоже отлично работает. Результат:
Итак, мой вопрос: как объединить два моих сценария, чтобы три раскрывающихся списка одновременно, чтобы выбрать сервер, дату и FS нужна?
Спасибо!