Networkx:如何绘制彩色边缘?

时间:2010-10-16 21:33:16

标签: python networkx

我使用以下代码构建了一个图表:

G = networkx.Graph()
G.add_edges_from([list(e) for e in P + Q + R])    
colors = "bgrcmyk"
color_map = [colors[i] for i in range(n/2)]

# add colors
for i in range(len(P)):
    edge = list(P[i])
    G[edge[0]][edge[1]]['edge_color'] = color_map[i]

for i in range(len(P)):
    edge = list(Q[perms[0][i]])
    G[edge[0]][edge[1]]["color"] = color_map[perms[0][i]]

for i in range(len(P)):
    edge = list(R[perms[1][i]])
    G[edge[0]][edge[1]]["color"] = color_map[perms[1][i]]

然后我使用:

显示
networkx.draw(G)
matplotlib.pyplot.show()

它显示正常,但所有边缘都用黑色着色,而不是我在上面的代码段中尝试分配的颜色。有什么想法吗?

3 个答案:

答案 0 :(得分:6)

您可以在不循环绘制边缘的情况下执行此操作。对于较大的图形,它会更快。

import networkx as nx
import matplotlib.pyplot as plt

G = nx.Graph()
# example graph 
for color in "bgrcmyk":
    G.add_edge('s'+color,'t'+color, color=color)

# edge_color_attr = nx.get_edge_attributes(G,'color')
# edges = edge_color_attr.keys()
# colors = edge_color_attr.values()
edges,colors = zip(*nx.get_edge_attributes(G,'color').items())
nx.draw(G,edgelist=edges,edge_color=colors,width=10)
plt.show()

答案 1 :(得分:1)

嗯,终于找到了我需要做的事情。显然需要分离颜色,需要使用draw_networkx绘制网络。因此,上述三个for循环将替换为:

pos=networkx.spring_layout(G)
for i in range(len(P)):
    networkx.draw_networkx_edges(G,pos,
                edgelist=[list(P[i]), list(Q[perms[0][i]]), list(R[perms[1][i]])],edge_color=color_map[i], width="8")

答案 2 :(得分:0)

文档字符串显示:

  

edge_color:颜色字符串或浮点数组          边缘颜色。可以是单色格式字符串(默认='r'),          或与edgelist长度相同的一系列颜色。          如果指定了数值,它们将映射到          使用edge_cmap和edge_vmin,edge_vmax参数的颜色。