python – 将配对值的元组(或列表列表)元组拆分为独立的完整集?

我在csv文件中配对了值.配对值都不一定是唯一的.我想将这个大型清单拆分成独立的完整集,以便进一步分析.

为了说明,我的“megalist”就像:

megalist = [['a','b'],['a','d'],['b','f'],['r','s'],['t','r']...]

最重要的是,输出将保留配对值列表(即,不合并值).理想情况下,输出最终会导致不同的csv文件,以便以后进行单独分析.例如,这个预言家将是:

completeset1 = [['a','f']]
completeset2 = [['r','r']]
...

在图论背景中,我试图获取互斥子图的巨大图(其中配对值是连接顶点)并将它们拆分成更易于管理的独立图.感谢您的任何意见!

编辑1:这使我处于一个可以向前迈进的地方.再次感谢!

import sys,csv
import networkx as nx

megalist = csv.reader(open('megalistfile.csv'),delimiter = '\t')

G = nx.Graph()
G.add_edges_from(megalist)

subgraphs = nx.connected_components(G)

output_file = open('subgraphs.txt','w')

for subgraph in subgraphs:
     output_line = str(G.edges(subgraph)) + '\n'
     output_file.write(output_line)

output_file.close()
最佳答案
您可以使用networkx.构建图表:

>>> import networkx as nx
>>> megalist = [['a','r']]
>>> G = nx.Graph()
>>> G.add_edges_from(megalist)

然后获取subgrahs列表:

>>> subgraphs = nx.connected_components(G)
>>> subgraphs
[['a','b','d',['s','r','t']]
>>> [G.edges(subgraph) for subgraph in subgraphs]
[[('a','b'),('a','d'),('b','f')],[('s','r'),('r','t')]]

相关文章

Python中的函数(二) 在上一篇文章中提到了Python中函数的定...
Python中的字符串 可能大多数人在学习C语言的时候,最先接触...
Python 面向对象编程(一) 虽然Python是解释性语言,但是它...
Python面向对象编程(二) 在前面一篇文章中谈到了类的基本定...
Python中的函数(一) 接触过C语言的朋友对函数这个词肯定非...
在windows下如何快速搭建web.py开发框架 用Python进行web开发...