繁体   English   中英

如何从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中,您需要先拆分为一个变量,然后分配给xy

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM