2010-11-18 20 views
0

如何解析以下文件,并将每行转换为列表元素(每行开始处有空格)?不幸的是我在正则表达式总是吸:/所以把这个:将多行文件的内容更改为列表

32.42.4.120', '32.42.4.127 
32.42.5.128', '32.42.5.255 
32.42.15.136', '32.42.15.143 
32.58.129.0', '32.58.129.7 
32.58.131.0', '32.58.131.63 
46.7.0.0', '46.7.255.255 

到一个列表:

('32.42.4.120', '32.42.4.127'), 
('32.42.5.128', '32.42.5.255'), 
('32.42.15.136', '32.42.15.143'), 
('32.58.129.0', '32.58.129.7'), 
('32.58.131.0', '32.58.131.63'), 
+0

最后一行发生了什么? – SilentGhost 2010-11-18 14:38:44

回答

1

这个怎么样? (如果我错了,至少让我知道下来之前投票)

>>> x = [tuple(line.strip().split("', '")) for line in open('file')] 
>>> x 
[('32.42.4.120', '32.42.4.127'), ('32.42.5.128', '32.42.5.255'), ('32.42.15.136', '32.42.15.143'), ('32.58.129.0', '32.58.129.7'), ('32.58.131.0', '32.58.131.63'), ('46.7.0.0', '46.7.255.255')] 
1

没有需要的正则表达式:

l = [] 

with open("name_file", "r") as f: 
    for line in f: 
     l.append(line.split(", ")) 
如果要删除第一个空间

并有元组你可以做:

l = [] 

with open("name_file", "r") as f: 
    for line in f: 
     data = line.split(", ") 
     l.append((data[0].strip(), data[1].strip())) 
+0

缺少尼特 - 他有领先的空白,所以它需要是line.strip()。split() – bgporter 2010-11-18 14:38:39

1
l = [] 
f = open("test_data.txt") 
for line in f: 
elems = line[1:-1].split("', '") 
l.append((elems[0], elems[1])) 
f.close() 

print l 

输出:

[('32 .42.4.120' ,'32 .42.4.127' ) ,('32.42.5.128','32.42.5.255'),('32.42.15.136','32.42.15.143'),('32.58.129.0','32.58.129.7'),('32.58.131.0', '32 .58.131.63'),('46.7.0.0','46 .7.255.25')]