![](/img/trans.png)
[英]Read a file with an edge list for a graph and create adjacency list in Python
[英]How to read a graph from a file in python to get its adjacency list?
我正在从一个文件中读取,该文件具有代表图形及其邻接列表的数字。第一个数字是顶点,其余的是邻居。
假设我有一个用空格分隔的数字字符串存储在字符串中:1 2 3 4。
我如何拆分它,使x = 1和y为列表[2,3,4]?
y=[]
g=open('graph','r')
for line in g:
x,y=line.split()
在Python 3中,您可以执行以下操作:
x, *y = line.split()
但是在Python 2中,您需要先拆分为一个变量,然后分配给x
和y
:
values = line.split()
x, y = values[0], values[1:]
如果这些需要是整数而不是字符串,则需要首先将值映射到int()
:
x, *y = map(int, line.split())
或者,再次使用Python 2:
values = map(int, line.split())
x, y = values[0], values[1:]
Python 3演示:
>>> x, *y = '1 2 3 4'.split()
>>> x, y
('1', ['2', '3', '4'])
>>> x, *y = map(int, '1 2 3 4'.split())
>>> x, y
(1, [2, 3, 4])
Python 2:
>>> values = '1 2 3 4'.split()
>>> x, y = values[0], values[1:]
>>> x, y
('1', ['2', '3', '4'])
>>> values = map(int, '1 2 3 4'.split())
>>> x, y = values[0], values[1:]
>>> x, y
(1, [2, 3, 4])
这是使用Namedtuple [1]以面向对象的方式存储数据的解决方案。
Namedtuple是一个生成器,用于创建用于存储数据的小类。 生成的类可以自行打印,这对于调试非常有用。 但是,这些对象是不可变的,要更改任何内容,必须创建新的对象。
from collections import namedtuple
VertexInfo = namedtuple("VertexInfo", "vert, adj")
graph = []
g = open('graph','r')
for line in g:
nums = line.split()
info = VertexInfo(vert=nums[0], adj=nums[1:])
graph.append(info)
您可以使用以下方法获得第一个顶点编号:
graph[0].vert
和第一个邻接列表
graph[0].adj
[1] http://docs.python.org/2/library/collections.html#collections.namedtuple
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.