我想比较图中不同边的节点。如何从边缘(n1,n2)获取节点(n1 和 n2)?
问问题
6037 次
2 回答
4
NetworkX中的一条边是由它的节点定义的,所以我不确定你在这里问的是什么。图中的特定边只是一个节点元组,具有可选的权重。
import networkx as nx
g = nx.Graph()
g.add_edge(1,2)
g.add_edge(2,3)
g.edges()
给
[(1, 2), (2, 3)]
如您所见,边列表明确提供了每条边的节点。
更新:这是你想要的吗?
#!/usr/bin/python
import networkx as nx
import random
g = nx.Graph()
g.add_edges_from([(1,2),(2,3),(1,4),(2,5)])
random_edge = random.choice(g.edges())
print 'Randomly selected edge is:', random_edge
print 'Nodes are', random_edge[0], 'and', random_edge[1]
于 2010-05-01T14:52:25.720 回答
0
我认为是预期问题的答案是:
graph = networkx.read_graphml('some_fully_loaded_graph.graphml')
edge0 = list(graph.edges(data=True))[0]
subgraph = graph.edge_subgraph([edge0[:2]])
nodes0 = list(subgraph.nodes(data=True))
于 2021-03-10T21:12:43.450 回答