Plotly Dash:在 Python 中绘制 networkx

Posted

技术标签:

【中文标题】Plotly Dash:在 Python 中绘制 networkx【英文标题】:Plotly Dash: Plotting networkx in Python 【发布时间】:2021-05-03 17:29:48 【问题描述】:

我正在尝试在 Python dash 中绘制 Networkx 图形以动态更改它。生成networkx图形的代码如下:

def networkGraph(EGDE_VAR):
    edges = [[EGDE_VAR,'B'],['B','C'],['B','D']]
    G = nx.Graph()
    G.add_edges_from(edges)
    pos = nx.spring_layout(G)
    plt.figure()    
    fig = nx.draw(G,pos,edge_color='black',width=1,linewidths=1,\
    node_size=500,node_color='pink',alpha=0.9,\
    labels=node:node for node in G.nodes())
    return(fig)

EGDE_VAR = 'K'
networkGraph(EGDE_VAR)

如果我尝试运行上述函数,它工作正常,所以我得到:

现在我想创建一个 Python 破折号,通过将其设置到输入框中来动态更改 EDGE_VAR。所以我尝试了:

#-*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output

# import the css template, and pass the css template into dash
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
app.title = "Dash Networkx"

EGDE_VAR = 'R'

# Input box para procurar o sinistro
app.layout = html.Div([    
        html.I("Write your EDGE_VAR"),
        html.Br(),
        dcc.Input(id="EGDE_VAR", type="text", placeholder=""),
        dcc.Graph(id='my-graph'),
    ]
)

@app.callback(
    Output("my-graph", "figure"),
    [Input("EGDE_VAR", "value")],
)
def update_output(EGDE_VAR):
    return networkGraph(EGDE_VAR)

if __name__ == '__main__':
    app.run_server(debug=True, use_reloader=False)

但它不起作用。有什么想法吗?

【问题讨论】:

【参考方案1】:

您的代码的问题是 networkGraph() 函数没有返回 Plotly 图形对象,请参阅 Plotly documentation on network graphs:

import dash
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output
import plotly.graph_objects as go
import networkx as nx

# Plotly figure
def networkGraph(EGDE_VAR):

    edges = [[EGDE_VAR, 'B'], ['B', 'C'], ['B', 'D']]
    G = nx.Graph()
    G.add_edges_from(edges)
    pos = nx.spring_layout(G)

    # edges trace
    edge_x = []
    edge_y = []
    for edge in G.edges():
        x0, y0 = pos[edge[0]]
        x1, y1 = pos[edge[1]]
        edge_x.append(x0)
        edge_x.append(x1)
        edge_x.append(None)
        edge_y.append(y0)
        edge_y.append(y1)
        edge_y.append(None)

    edge_trace = go.Scatter(
        x=edge_x, y=edge_y,
        line=dict(color='black', width=1),
        hoverinfo='none',
        showlegend=False,
        mode='lines')

    # nodes trace
    node_x = []
    node_y = []
    text = []
    for node in G.nodes():
        x, y = pos[node]
        node_x.append(x)
        node_y.append(y)
        text.append(node)

    node_trace = go.Scatter(
        x=node_x, y=node_y, text=text,
        mode='markers+text',
        showlegend=False,
        hoverinfo='none',
        marker=dict(
            color='pink',
            size=50,
            line=dict(color='black', width=1)))

    # layout
    layout = dict(plot_bgcolor='white',
                  paper_bgcolor='white',
                  margin=dict(t=10, b=10, l=10, r=10, pad=0),
                  xaxis=dict(linecolor='black',
                             showgrid=False,
                             showticklabels=False,
                             mirror=True),
                  yaxis=dict(linecolor='black',
                             showgrid=False,
                             showticklabels=False,
                             mirror=True))

    # figure
    fig = go.Figure(data=[edge_trace, node_trace], layout=layout)

    return fig

# Dash app
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
app.title = 'Dash Networkx'

app.layout = html.Div([
        html.I('Write your EDGE_VAR'),
        html.Br(),
        dcc.Input(id='EGDE_VAR', type='text', value='K', debounce=True),
        dcc.Graph(id='my-graph'),
    ]
)

@app.callback(
    Output('my-graph', 'figure'),
    [Input('EGDE_VAR', 'value')],
)
def update_output(EGDE_VAR):
    return networkGraph(EGDE_VAR)

if __name__ == '__main__':
    app.run_server(debug=True, host='0.0.0.0', port=1234)

【讨论】:

感谢您的回答。你知道如何在这个图中插入边标签吗?

以上是关于Plotly Dash:在 Python 中绘制 networkx的主要内容,如果未能解决你的问题,请参考以下文章

通过 Matplotlib 用 Dash 绘制有向图

在 python dash plotly 主题中更改颜色

Plotly (Dash) 勾选标签覆盖

Choropleth Plotly Graph 未出现在 Dash 上

Plotly Dash 回调错误更新输出图

即使屏幕尺寸在 Dash-plotly 中使用 python 改变,如何在导航栏中固定按钮的位置