【发布时间】:2021-08-02 15:31:11
【问题描述】:
我试图在 Python Dash 中嵌入的交互式条形图中可视化不同金融基准(A、X)的加权方案。每个基准由具有不同权重的不同指标组成。切换或取消选择基准时,条形图应相应更改。不知何故,我无法正确调整代码的回调部分,因为我无法创建条形图。有人熟悉这个问题吗?
我正在使用 Jupyter Notebook。这是我的数据示例代码:
包和数据:
import pandas as pd
import dash
import dash_html_components as html
import dash_core_components as dcc
from dash.dependencies import Input, Output
import plotly.express as px
data = [['A', 'B', 0.4], ['A', 'C', 0.5], ['A', 'D', 0.1], ['X', 'Y', 0.15], ['X', 'Z', 0.85]]
df = pd.DataFrame(data, columns = ['BM_NAME', 'INDEX_NAME', 'WEIGHT'])
df
条形图。在 dash 中,想法是为单个选定的基准测试显示单个条形图(因此“multi”设置为“false”):
barchart = px.bar(
data_frame=df,
x="BM_NAME",
y="WEIGHT",
color="INDEX_NAME",
opacity=0.9,
barmode='group')
barchart
破折号:
# create the Dash app
app = dash.Dash()
# set up app layout
app.layout = html.Div(children=[
html.H1(children='BM Composition'),
dcc.Dropdown(id='BM-dropdown',
options=[{'label': x, 'value': x}
for x in df.BM_NAME.unique()],
value='A',
multi=False, clearable=True),
dcc.Graph(id='bar-chart')
])
# set up the callback function
@app.callback(
Output(component_id="bar-chart", component_property="figure"),
[Input(component_id="BM-dropdown", component_property="value")],
)
def display_BM_composition(selected_BM):
dff = df.BM_NAME.unique() # Only use unique values in column "BM_NAME" selected in dropdown
barchart = px.bar(
data_frame=df,
x=filtered_BM,
y="WEIGHT",
color="INDEX_NAME",
opacity=0.9,
barmode='group')
return barchart
# Run local server
if __name__ == '__main__':
app.run_server(debug=True, use_reloader=False)
非常感谢任何帮助或改进建议!
【问题讨论】:
标签: python callback bar-chart plotly-dash dashboard