Я хочу создать раскрывающуюся панель инструментов, в которой пользователь выбирает значения из столбца.И конечный результат - это значение из другого столбца.
Например, если я выберу «Низкую задержку» из Col_1, «Пиковый месяц» из Col_2, «Пиковый час» из Col_3, «90» из Col_4, тогда окончательныйвыходные данные должны показывать соответствующие значения из Final_1 и Final_2, которые являются «3» и «44».
Я попытался сделать это на dash Python.Я искал следующую ссылку: - "https://community.plot.ly/t/dynamic-controls-and-dynamic-output-components/5519"
Пример df, на котором я выполняю код
Это мой код, я вводилзначения вручную, так как я сталкиваюсь с проблемой передачи значений.
app = dash.Dash()
app.layout = html.Div([
dcc.Dropdown(
id='datasource-1',
options=[
{'label': i, 'value': i} for i in ['Low Delay','High Delay']
],
),
dcc.Dropdown(
id='datasource-2',
options=[
{'label': i, 'value': i} for i in ['Peak Month','Non Peak Month']
]
),
dcc.Dropdown(
id='datasource-3',
options=[
{'label': i, 'value': i} for i in ['Peak Hour', 'Non Peak Hour']
]
),
dcc.Dropdown(
id='datasource-4',
options=[
{'label': i, 'value': i} for i in ['60','90','120','150','>180']
]
),
html.Hr(),
html.Div('Select Hour and Threshold Delay'),
html.Div(
id='controls-container'
),
html.Hr(),
html.Div('Output'),
html.Div(
id='output-container'
)
])
def generate_control_id(value):
return 'Control {}'.format(value)
DYNAMIC_CONTROLS = {
'Low Delay': dcc.Dropdown(
id=generate_control_id('Low Delay'),
options=[{'label': '{}'.format(i), 'value': i} for i in ['Peak Hour', 'Non Peak Hour']]
),
'High Delay': dcc.Dropdown(
id=generate_control_id('High Delay'),
options=[{'label': '{}'.format(i), 'value': i} for i in ['Peak Hour', 'Non Peak Hour']]
),
'Peak Month': dcc.Dropdown(
id=generate_control_id('X'),
options=[{'label': '{}'.format(i), 'value': i} for i in ['60','90','120','150','>180']]
),
'Non Peak Month': dcc.Dropdown(
id=generate_control_id('Y'),
options=[{'label': 'Dropdown Y: {}'.format(i), 'value': i} for i in ['60','90','120','150','>180']]
)
}
@app.callback(
Output('controls-container', 'children'),
[Input('datasource-1', 'value'),
Input('datasource-2', 'value')])
def display_controls(datasource_1_value, datasource_2_value):
# generate 2 dynamic controls based off of the datasource selections
return html.Div([
DYNAMIC_CONTROLS[datasource_1_value],
DYNAMIC_CONTROLS[datasource_2_value],
])
def generate_output_id(value1, value2):
return '{} {} container'.format(value1, value2)
@app.callback(
Output('output-container', 'children'),
[Input('datasource-1', 'value'),
Input('datasource-2', 'value')])
def display_controls(datasource_1_value, datasource_2_value):
# create a unique output container for each pair of dyanmic controls
return html.Div(id=generate_output_id(
datasource_1_value,
datasource_2_value
))
def generate_output_callback(datasource_1_value, datasource_2_value):
def output_callback(control_1_value, control_2_value):
# This function can display different outputs depending on
# the values of the dynamic controls
return '''
You have selected {} and {} which were
generated from {} (datasource 1) and and {} (datasource 2)
'''.format(
control_1_value,
control_2_value,
datasource_1_value,
datasource_2_value
)
return output_callback
app.config.supress_callback_exceptions = True
for value1, value2 in itertools.product(
[o['value'] for o in app.layout['datasource-1'].options],
[o['value'] for o in app.layout['datasource-2'].options]):
app.callback(
Output(generate_output_id(value1, value2), 'children'),
[Input(generate_control_id(value1), 'value'),
Input(generate_control_id(value2), 'value')])(
generate_output_callback(value1, value2)
)
if __name__ == '__main__':
app.run_server()
Ожидание чего-то похожего
Я хочу ожидаемый вывод на моем фрейме данных. Если я выберу «Низкая задержка»»Из Col_1,« Peak Month »из Col_2,« Peak Hour »из Col_3,« 90 »из Col_4, тогда в конечном выводе должны отображаться соответствующие значения из Final_1 и Final_2, которые равны« 3 »и« 44 »