如何在python中使用networkx绘制有向图?

bra*_*orm 86 python plot graph networkx

我有一些节点来自我想要映射到图表的脚本.在下面,我想使用箭头从A到D,并且边缘也可能有颜色(红色或其他东西).这基本上就像所有其他节点都存在时从A到D的路径.您可以将每个节点想象为城市,从A到D行进需要方向(带箭头).下面的代码构建了图表

import networkx as nx
import numpy as np
import matplotlib.pyplot as plt

G = nx.Graph()
G.add_edges_from(
    [('A', 'B'), ('A', 'C'), ('D', 'B'), ('E', 'C'), ('E', 'F'),
     ('B', 'H'), ('B', 'G'), ('B', 'F'), ('C', 'G')])

val_map = {'A': 1.0,
           'D': 0.5714285714285714,
           'H': 0.0}

values = [val_map.get(node, 0.25) for node in G.nodes()]

nx.draw(G, cmap = plt.get_cmap('jet'), node_color = values)
plt.show()
Run Code Online (Sandbox Code Playgroud)

但我想要一些像图中所示的东西.在此输入图像描述 在此输入图像描述

第一个图像的箭头和第二个图像的红色边缘.谢谢

Mar*_*ius 75

完全充实的例子,只有红色边缘的箭头:

import networkx as nx
import matplotlib.pyplot as plt

G = nx.DiGraph()
G.add_edges_from(
    [('A', 'B'), ('A', 'C'), ('D', 'B'), ('E', 'C'), ('E', 'F'),
     ('B', 'H'), ('B', 'G'), ('B', 'F'), ('C', 'G')])

val_map = {'A': 1.0,
           'D': 0.5714285714285714,
           'H': 0.0}

values = [val_map.get(node, 0.25) for node in G.nodes()]

# Specify the edges you want here
red_edges = [('A', 'C'), ('E', 'C')]
edge_colours = ['black' if not edge in red_edges else 'red'
                for edge in G.edges()]
black_edges = [edge for edge in G.edges() if edge not in red_edges]

# Need to create a layout when doing
# separate calls to draw nodes and edges
pos = nx.spring_layout(G)
nx.draw_networkx_nodes(G, pos, cmap=plt.get_cmap('jet'), 
                       node_color = values, node_size = 500)
nx.draw_networkx_labels(G, pos)
nx.draw_networkx_edges(G, pos, edgelist=red_edges, edge_color='r', arrows=True)
nx.draw_networkx_edges(G, pos, edgelist=black_edges, arrows=False)
plt.show()
Run Code Online (Sandbox Code Playgroud)

红色边缘

  • 我们的两张更新后的图片有多么不同,真是太疯狂了。+1用于计算边缘颜色! (2认同)

Bac*_*ics 43

我只是为了完整而把它放进去.我从marius和mdml中学到了很多东西.这是边缘权重.抱歉箭头.看起来我不是唯一一个说它无法帮助的人.我无法使用ipython笔记本渲染这个我不得不直接从python中获取我的边缘权重的问题.

import networkx as nx
import numpy as np
import matplotlib.pyplot as plt
import pylab

G = nx.DiGraph()

G.add_edges_from([('A', 'B'),('C','D'),('G','D')], weight=1)
G.add_edges_from([('D','A'),('D','E'),('B','D'),('D','E')], weight=2)
G.add_edges_from([('B','C'),('E','F')], weight=3)
G.add_edges_from([('C','F')], weight=4)


val_map = {'A': 1.0,
                   'D': 0.5714285714285714,
                              'H': 0.0}

values = [val_map.get(node, 0.45) for node in G.nodes()]
edge_labels=dict([((u,v,),d['weight'])
                 for u,v,d in G.edges(data=True)])
red_edges = [('C','D'),('D','A')]
edge_colors = ['black' if not edge in red_edges else 'red' for edge in G.edges()]

pos=nx.spring_layout(G)
nx.draw_networkx_edge_labels(G,pos,edge_labels=edge_labels)
nx.draw(G,pos, node_color = values, node_size=1500,edge_color=edge_colors,edge_cmap=plt.cm.Reds)
pylab.show()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

  • 我跑了这个并没有得到节点标签.您需要添加以下内容:`node_labels = {node:节点在G.nodes()中的节点}; nx.draw_networkx_labels(G,pos,labels = node_labels)`. (8认同)

小智 19

您可能希望使用以下代替常规nx.draw:

nx.draw_networkx(G[, pos, arrows, with_labels])
Run Code Online (Sandbox Code Playgroud)

例如:

nx.draw_networkx(G, arrows=True, **options)
Run Code Online (Sandbox Code Playgroud)

您可以通过初始化**变量来添加选项,如下所示:

options = {
    'node_color': 'blue',
    'node_size': 100,
    'width': 3,
    'arrowstyle': '-|>',
    'arrowsize': 12,
}
Run Code Online (Sandbox Code Playgroud)

还有一些函数支持directed=True parameter 在这种情况下,这个状态是默认状态:

G = nx.DiGraph(directed=True)
Run Code Online (Sandbox Code Playgroud)

可以在此处找到networkx参考.

带有箭头图像的图形

  • 最好能给出一个有效的例子 (2认同)

mdm*_*dml 18

您需要使用有向图而不是图,即

G = nx.DiGraph()
Run Code Online (Sandbox Code Playgroud)

然后,创建要使用的边缘颜色列表并将其传递给nx.draw(如@Marius所示).

把这一切放在一起,我得到下面的图像.仍然不是你展示的其他图片(我不知道你的边缘重量来自哪里),但更接近!如果您想要更好地控制输出图形的外观(例如,获得看起来像箭头的箭头),我会使用Graphviz检查NetworkX.

在此输入图像描述


小智 5

import networkx as nx
import matplotlib.pyplot as plt

g = nx.DiGraph()
g.add_nodes_from([1,2,3,4,5])
g.add_edge(1,2)
g.add_edge(4,2)
g.add_edge(3,5)
g.add_edge(2,3)
g.add_edge(5,4)

nx.draw(g,with_labels=True)
plt.draw()
plt.show()
Run Code Online (Sandbox Code Playgroud)

这很简单,如何使用networkx使用python 3.x绘制有向图.只是简单的表示,可以修改和着色等.请在此处查看生成的图表.

注意:这只是一个简单的表示.可以添加加权边缘

g.add_edges_from([(1,2),(2,5)], weight=2)
Run Code Online (Sandbox Code Playgroud)

因此再次绘制.


小智 5

import networkx as nx
import matplotlib.pyplot as plt

G = nx.DiGraph()
G.add_node("A")
G.add_node("B")
G.add_node("C")
G.add_node("D")
G.add_node("E")
G.add_node("F")
G.add_node("G")
G.add_edge("A","B")
G.add_edge("B","C")
G.add_edge("C","E")
G.add_edge("C","F")
G.add_edge("D","E")
G.add_edge("F","G")

print(G.nodes())
print(G.edges())

pos = nx.spring_layout(G)

nx.draw_networkx_nodes(G, pos)
nx.draw_networkx_labels(G, pos)
nx.draw_networkx_edges(G, pos, edge_color='r', arrows = True)

plt.show()
Run Code Online (Sandbox Code Playgroud)