我正在学习dash教程,完全不知道dash是如何调用函数的。在本页的第二个tute之后,https://dash.plotly.com/basic-callbacks。下面显示了相同的示例。我完全不知道在哪里调用了update_figure函数,但图形仍然在仪表板中绘制(即在app.layout或app.callback中的任何地方都没有提到update_figure()函数)。
那么关于函数是如何传递的,你有什么想法吗?
df = pd.read_csv('https://raw.githubusercontent.com/plotly/datasets/master/gapminderDataFiveYear.csv')
# initialize
app = dash.Dash()
app.layout = html.Div([
dcc.Graph(id = 'graph-with-slider'),
dcc.Slider(
id = 'year-slider',
min = df['year'].min(),
max = df['year'].max(),
value = df['year'].min(),
marks = {str(year) : str(year) for year in df['year'].unique()},
step = None
)
])
@app.callback(
Output('graph-with-slider','figure'),
[Input('year-slider','value')]
)
def update_figure(selected_year):
filtered_df = df[df.year == selected_year]
fig = px.scatter(filtered_df, x = 'gdpPercap', y = 'lifeExp', size = 'pop', color = 'continent', hover_name = 'country', log_x = True, size_max = 55)
fig.update_layout(transition_duration = 500)
return fig
if __name__ == '__main__':
app.run_server()发布于 2020-07-02 08:09:53
Dash使用@app.callback装饰器在幕后做到这一点。每当输入发生变化时,就会调用该函数,Dash将从回调中获取返回值来更新输出。
https://stackoverflow.com/questions/62672368
复制相似问题