How to stop Networkx from changing the order of edges when adding them from a list?

前端 未结 2 959
攒了一身酷
攒了一身酷 2021-01-21 08:23

Adding edges from a list to a graph in NetworkX (python) changes the order of the edges, which causes problems for me when drawing the Graph. As example:

import          


        
相关标签:
2条回答
  • 2021-01-21 09:06

    If you use a traversal algorithm you can get the edges in the order they were visited in the path

    ```

    paths = nx.all_simple_paths(G, source=0, target=3) for path in map(nx.utils.pairwise, paths): ... print(list(path)) [(0, 1), (1, 2), (2, 3)] [(0, 1), (1, 3)] [(0, 2), (2, 1), (1, 3)] [(0, 2), (2, 3)] [(0, 3)] ```

    0 讨论(0)
  • 2021-01-21 09:18

    The answer to your question is a bit messy because the NetworkX Graph class doesn't retain the order of nodes in an edge. However, this can be circumvented by sorting each edge to guarantee node order. G.edges() can also be sorted by a custom key that retrieves the index that each edge appears in the edge list.

    import networkx as nx
    
    edgelist  = [['C','B'],['A','B'],['A','C']]
    

    First, sort the nodes in each edge and create a dictionary that maps each edge to its index in the edge list:

    edgelist = [sorted(edge) for edge in edgelist]
    mapping = {tuple(edge): index for (edge, index) in zip(edgelist, range(len(edgelist)))}
    

    Then sort the order of the graph's edges according to the index edges in the edge list:

    G = nx.Graph()
    G.add_edges_from(edgelist)
    sorted(G.edges(), key=lambda edge: mapping[tuple(sorted(list(edge)))])
    
    0 讨论(0)
提交回复
热议问题