python - Plotly Choropleth Map Plots 的下拉菜单

标签 python drop-down-menu plotly choropleth plotly-python

我正在尝试创建等值分布图。下面是一个有效的例子:

df = px.data.gapminder().query("year==2007")

fig = go.Figure(data=go.Choropleth(
    locations=happy['iso'], # Spatial coordinates
    z = happy['Happiness'].astype(float), # Data to be color-coded
    colorbar_title = "Happiness Score",
))

fig.update_layout(
    title_text = 'Life Expectancy in 2007'
)

fig.show()

但是,我想创建一个下拉菜单来更改不同变量(例如,预期生命周期、GDP、人口)之间的绘图值。我相信这是可能的,但还没有在网上看到任何教程。他们中的大多数只使用其他类型的条形图或散点图。

这是我到目前为止所得到的:
# Initialize figure
fig = go.Figure()

# Add Traces
fig.add_trace(go.Figure(data=go.Choropleth(
    locations=df['iso_alpha'], # Spatial coordinates
    z = df['lifeExp'].astype(float), # Data to be color-coded
    colorbar_title = "Life Expectancy")))

fig.add_trace(go.Figure(data=go.Choropleth(
    locations=df['iso_alpha'], # Spatial coordinates
    z = df['gdpPercap'].astype(float), # Data to be color-coded
    colorbar_title = "GDP per capita")))

但我不确定如何从这里开始。我是否需要通过 fig.update_layout 或其他方式更新图形的布局?

最佳答案

有两种方法可以解决这个问题

短跑

# save this as app.py
import pandas as pd
import plotly.graph_objs as go
import plotly.express as px
import dash
import dash_core_components as dcc
import dash_html_components as html

# Data
df = px.data.gapminder().query("year==2007")

df = df.rename(columns=dict(pop="Population",
                            gdpPercap="GDP per Capita",
                            lifeExp="Life Expectancy"))

cols_dd = ["Population", "GDP per Capita", "Life Expectancy"]

app = dash.Dash()
app.layout = html.Div([
    dcc.Dropdown(
        id='demo-dropdown',
        options=[{'label': k, 'value': k} for k in cols_dd],
        value=cols_dd[0]
    ),

    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):
    fig = go.Figure()
    fig.add_trace(go.Choropleth(
       locations=df['iso_alpha'], # Spatial coordinates
        z=df[value].astype(float), # Data to be color-coded
        colorbar_title=value))
    fig.update_layout(title=f"<b>{value}</b>", title_x=0.5)
    return fig

if __name__ == '__main__':
    app.run_server()

将此作为 python app.py 运行然后转至 http://127.0.0.1:8050

plotly

在这种情况下,我们需要处理不同轨迹的可见性,并以显示一条轨迹并隐藏所有其他轨迹的方式创建按钮。

import pandas as pd
import numpy as np
import plotly.graph_objs as go
import plotly.express as px

# Data
df = px.data.gapminder().query("year==2007")
df = df.rename(columns=dict(pop="Population",
                            gdpPercap="GDP per Capita",
                            lifeExp="Life Expectancy"))
cols_dd = ["Population", "GDP per Capita", "Life Expectancy"]
# we need to add this to select which trace 
# is going to be visible
visible = np.array(cols_dd)

# define traces and buttons at once
traces = []
buttons = []
for value in cols_dd:
    traces.append(go.Choropleth(
       locations=df['iso_alpha'], # Spatial coordinates
        z=df[value].astype(float), # Data to be color-coded
        colorbar_title=value,
        visible= True if value==cols_dd[0] else False))

    buttons.append(dict(label=value,
                        method="update",
                        args=[{"visible":list(visible==value)},
                              {"title":f"<b>{value}</b>"}]))

updatemenus = [{"active":0,
                "buttons":buttons,
               }]


# Show figure
fig = go.Figure(data=traces,
                layout=dict(updatemenus=updatemenus))
# This is in order to get the first title displayed correctly
first_title = cols_dd[0]
fig.update_layout(title=f"<b>{first_title}</b>",title_x=0.5)
fig.show()

关于python - Plotly Choropleth Map Plots 的下拉菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61750811/

相关文章:

php - 如何通过 laravel 的 lists() 传递不止 id 和 name

r - 在单个3D图中混合表面和散点图

python - 当给定 dict1 key2 时查找 dict1 key1 的值?

python - 刚刚安装了 BeautifulSoup Python 3.3.0

python - 搜索、计数和添加 - Python

html - CSS 下拉菜单,我做错了什么?

jquery - Bootstrap 下拉菜单无法按正确顺序使用脚本和链接

javascript - 如何控制 plotly.js 中轨迹的显示顺序?

javascript - Angular 2 应用程序中的 plotly 点击事件

python - 在 pythonanywhere 中更新自定义 python 模块的最佳实践或最有效的方法是什么?