我正在尝试弄清楚如何对多个国家的地块实施下拉菜单。我对破折号和情节相当陌生。这是我的代码:
import pandas as pd
import plotly.express as px
import dash
import dash_core_components as dcc
import dash_html_components as html
df = pd.read_csv('https://api.statbank.dk/v1/data/mpk100/CSV?valuePresentation=Value&timeOrder=Ascending&LAND=*&Tid=*', sep=';')
df = df[df['INDHOLD'] != '..']
df['rate'] = df['INDHOLD'].str.replace(',', '.').astype(float)
available_countries = df['LAND'].unique()
df.groupby('LAND')
app = dash.Dash()
app.layout = html.Div([
dcc.Graph(
id='mpk100'
),
dcc.Dropdown(
id = "dropdown_mpk100",
options=[{'label': i, 'value': i} for i in available_countries],
value=['DANMARK', 'USA'], #Initial values,
multi=True)
@app.callback(Output(component_id='fig-mpk100',component_property='figure'),
[Input(component_id='dropdown_mpk100', component_property='value')])
def update_df('value'):
return dep_var
app.run_server(debug=True, use_reloader=False) # Turn off reloader if inside Jupyter
使用此代码,可用国家/地区的下拉列表或破折号均不会显示图形。有人可以解释如何处理并给出解决方案吗?
答案 0 :(得分:1)
您的代码中缺少几个部分。特别是您没有生成任何数字。在这里,我基本上是对要绘制的所有国家/地区过滤df
,然后使用plotly.express
将它们全部绘制为线。如果愿意,您最终可以使用plotly.graph_objs
添加跟踪。
import pandas as pd
import plotly.express as px
import dash
import dash_core_components as dcc
import dash_html_components as html
df = pd.read_csv('https://api.statbank.dk/v1/data/mpk100/CSV?valuePresentation=Value&timeOrder=Ascending&LAND=*&Tid=*', sep=';')
df = df[df['INDHOLD'] != '..']
df['rate'] = df['INDHOLD'].str.replace(',', '.').astype(float)
available_countries = df['LAND'].unique()
app = dash.Dash()
app.layout = html.Div([
dcc.Dropdown(
id='demo-dropdown',
options=[{'label': k, 'value': k} for k in available_countries],
value=['Danmark', 'USA'],
multi=True
),
html.Hr(),
dcc.Graph(id='display-selected-values'),
])
@app.callback(
dash.dependencies.Output('display-selected-values', 'figure'),
[dash.dependencies.Input('demo-dropdown', 'value')])
def update_output(value):
ts = df[df["LAND"].isin(value)]
fig = px.line(ts, x="TID", y="rate", color="LAND")
return fig
if __name__ == '__main__':
app.run_server()