MultiDiGraph.to_undirected#
- MultiDiGraph.to_undirected(reciprocal=False, as_view=False)[source]#
返回有向图的无向表示。
- 参数:
- reciprocalbool (可选)
如果为 True,则仅保留在原始有向图中双向存在的边。
- as_viewbool (可选, 默认为 False)
如果为 True,则返回原始有向图的无向视图。
- 返回值:
- GMultiGraph
一个无向图,具有相同的名称和节点,并且如果 (u, v, data) 或 (v, u, data) 存在于有向图中,则包含边 (u, v, data)。如果两个方向的边都存在且边数据不同,则只创建一条边,边数据任意选择其中之一。如果需要,您必须手动检查并纠正此问题。
另请参阅
注意事项
这将返回边、节点和图属性的“深拷贝”,它会尝试完全复制所有数据和引用。
这与类似的 D=MultiDiGraph(G) 不同,后者返回数据的浅拷贝。
有关浅拷贝和深拷贝的更多信息,请参阅 Python 的 copy 模块,https://docs.pythonlang.cn/3/library/copy.html。
警告:如果您对 MultiDiGraph 进行了子类化,以便在数据结构中使用类似字典的对象,则这些更改不会转移到通过此方法创建的 MultiGraph。
示例
>>> G = nx.path_graph(2) # or MultiGraph, etc >>> H = G.to_directed() >>> list(H.edges) [(0, 1), (1, 0)] >>> G2 = H.to_undirected() >>> list(G2.edges) [(0, 1)]