Graph.edges#

property Graph.edges#

图的边视图,表示为 G.edges 或 G.edges()。

edges(self, nbunch=None, data=False, default=None)

EdgeView 提供了对边元组的集合式操作以及边属性查找功能。当被调用时,它还提供了一个 EdgeDataView 对象,该对象允许控制对边属性的访问(但不提供集合式操作)。因此, G.edges[u, v]['color'] 提供了边 (u, v) 的颜色属性值,而 for (u, v, c) in G.edges.data('color', default='red'): 遍历所有边,生成颜色属性,如果不存在颜色属性则使用默认值 'red'

Parameters:
nbunch单个节点、容器或所有节点(默认=所有节点)

视图将仅报告来自这些节点的边。

data字符串或布尔值,可选(默认=False)

在 3 元组 (u, v, ddict[data]) 中返回边属性。 如果为 True,则在 3 元组 (u, v, ddict) 中返回边属性字典。 如果为 False,则返回 2 元组 (u, v)。

default值,可选(默认=None)

用于没有请求属性的边的值。 仅在 data 不是 True 或 False 时相关。

Returns:
edgesEdgeView

边属性的视图,通常它迭代遍历 (u, v) 或 (u, v, d) 元组形式的边,但也可以用于属性查找,如 edges[u, v]['foo']

Notes

nbunch 中不在图中的节点将被(安静地)忽略。对于有向图,这将返回出边。

Examples

>>> G = nx.path_graph(3)  # 或 MultiGraph 等
>>> G.add_edge(2, 3, weight=5)
>>> [e for e in G.edges]
[(0, 1), (1, 2), (2, 3)]
>>> G.edges.data()  # 默认数据为 {}(空字典)
EdgeDataView([(0, 1, {}), (1, 2, {}), (2, 3, {'weight': 5})])
>>> G.edges.data("weight", default=1)
EdgeDataView([(0, 1, 1), (1, 2, 1), (2, 3, 5)])
>>> G.edges([0, 3])  # 仅来自这些节点的边
EdgeDataView([(0, 1), (3, 2)])
>>> G.edges(0)  # 仅来自节点 0 的边
EdgeDataView([(0, 1)])