Есть ли способ запустить готовое приложение Dash на двух разных вкладках? - PullRequest
0 голосов
/ 09 мая 2019

Я написал Dash App, где пользователи могут загружать CSV-файл и отображать его в виде графика. Он также содержит определенные обратные вызовы, которые изменяют цвет столбца на графике при нажатии на график, и выбранная строка в таблице поступает в продажу. Теперь у меня вопрос, как я могу запустить свое приложение на двух разных вкладках Dash, например, вы можете использовать два загруженных файла CSV и сравнить их для лучшего обзора.

Я уже пытался разделить свое приложение в структуре проекта, как показано ниже.

- app.py
- index.py
- apps
   |-- __init__.py
   |-- app1.py
   |-- app2.py

но действительно ли это нужно? Нужно ли подключать обратные вызовы в app.py и особенно какие из них для запуска моего приложения снова?

import base64
import dash_core_components as dcc
import dash_html_components as html
import dash_table_experiments as dt
from dash.dependencies import Input, Output, State
import dash
import pandas as pd
import io


app = dash.Dash()

app.scripts.config.serve_locally = True
app.config['suppress_callback_exceptions'] = True
image_filename = ---
encoded_image = base64.b64encode(open(image_filename, 'rb').read())

app.layout = html.Div([
    dcc.Upload(
        id='upload-data',
        children=html.Div([
            'Drag and drop',
            html.A('Select Files')
        ]),
        style={
            'width': '100%',
            'height': '60px',
            'lineHeight': '60px',
            'borderWidth': '1px',
            'borderStyle': 'dashed',
            'borderRadius': '5px',
            'textAlign': 'center',
            'margin': '10px'
        },

    ),

    html.Br(),
    html.Div("x axis"),
    dcc.Dropdown(id='x_Axis',
        multi = False,

    html.Div('y axis'),
    dcc.Dropdown(id='y_Axis',
        multi = True,


    html.Div(id='graph'),
    html.Br(),
    html.H5("Updated Table"),
    html.Div(dt.DataTable(rows=[{}], id='table', 
                          selected_row_indices=[], row_selectable=True))

    ])


# functions

# file upload function
def parse_contents():

#return graph function
return graph():

# colorchange
@app.callback
def update_selected_row_indices():

#update graph
@app.callback
def update_graph():

# callback table creation
@app.callback
def update_output():

#callback x dropdown
@app.callback
def updateX():

#callback y dropdown
@app.callback
def updateY():
...