单击按钮或复选框等其他组件后如何创建或安装破折号组件

Posted

技术标签:

【中文标题】单击按钮或复选框等其他组件后如何创建或安装破折号组件【英文标题】:How to create or mount dash component after clicking on other component like button or checkbox 【发布时间】:2021-06-12 18:09:25 【问题描述】:

我创建了一个全局 df 变量,还创建了一个 csv 文件上传组件和显示 df 列的组件。我想在加载组件选项更改的文件时出现此错误options[0].label in Dropdown with ID "col-1" is required but it was not provided. 我该如何解决这个问题?

这是我的代码示例:

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

app = dash.Dash()

# I create a global variable 
global df
app.layout = html.Div(

# upload component
dcc.Upload(
        id='upload-df',
        children=html.Div([#code ]),
        ),
    html.Div(id='output-upload'),
    html.button(id='show'),
    html.Div(id='col-choice', children=[
                        html.Label('column 2'),
                        dcc.Dropdown(id='col-1'),
                        html.Label('column 2'),
                        dcc.Dropdown(id='col-2')

)

# parser
def parse_contents(contents, filename, date):
     # code
@app.callback(Output('output-upload', 'children'),
              Input('upload-data', 'contents'),
              State('upload-data', 'filename'),
              State('upload-data', 'last_modified'))
def update_output(list_of_contents, list_of_names, list_of_dates):
    # code

@app.callback(
    Output('col-1', 'options'),
    Output('col-22', 'options'),
    Input('show', 'n_clicks')
)
def show_colomn_option(clicks):
    number_of_output = 8
    try:
        df
        return (['label': i, 'value': i for i in df.columns],)*2
    except NameError:
        return (['label': None, 'value': None],)*2

我像this中描述的那样编写上传组件

【问题讨论】:

【参考方案1】:

Dash 不能很好地支持全局变量,基本上它会破坏你的代码,所以你应该按照这里的描述进行操作https://dash.plotly.com/advanced-callbacks

【讨论】:

谢谢@Marc Telly

以上是关于单击按钮或复选框等其他组件后如何创建或安装破折号组件的主要内容,如果未能解决你的问题,请参考以下文章

SweetAlert2 第一次提示为啥不在中间

如何在角度中禁用matchip

单击单选按钮或复选框时表单滚动到顶部

关于Swing中JFrame或JPanel重写paint()方法后再在JFrame或JPanel中添加其他组件出现按钮等组件消失不见只有当鼠标扫过时才会出现的问题

windows snmp 怎么查看信息

如何搭建Microsoft的DNS