我使用以下代码构建了一个图表:
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()
它显示正常,但所有边缘都用黑色着色,而不是我在上面的代码段中尝试分配的颜色。有什么想法吗?
答案 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参数的颜色。