我想从我的python代码中读取文本文件 link123.txt 。文本文件包含3行。
[ '_propA', 'propA', 'propB' ] 1 1 A { _propA: 1, propA: [Getter/Setter], propB: null }
我需要在“target”变量&中分配行的第一部分(url)。第二部分(链接名称)到“名称”变量(供进一步使用)。
到目前为止代码:
www.link1.com | linkname1
www.link2.com | linkname2
www.link3.com | linkname3
我的问题是如何从一行(“|”)中得到两个值 任何指导都将非常感谢。
答案 0 :(得分:1)
您可以使用str.split
按分隔符分割字符串:
>>> 'www.link1.com | linkname1'.split(' | ')
['www.link1.com', 'linkname1']
然后,使用iterable-unpacking(或多个赋值)保存到变量:
>>> target, name = 'www.link1.com | linkname1'.split(' | ')
>>> target
'www.link1.com'
>>> name
'linkname1'
with open("link123.txt") as f:
for line in f:
target, name = line.strip().split(' | ')
# Do something with `target`, `name`
注意:迭代文件对象将产生线条。您不需要使用file.readlines()
返回所有行的列表,除非您需要一次所有行。
<强>更新强>
如果您想要目标,名称列表,可以使用zip
:
>>> rows = [['link1', 'name1'], ['link2', 'name2'], ['link3', 'name3']]
>>> zip(*rows)
[('link1', 'link2', 'link3'), ('name1', 'name2', 'name3')]
# In Python 3.x, zip will return `zip` object instead of list.
with open("link123.txt") as f:
targets, names = zip(*[line.strip().split(' | ') for line in f])
# targets, names = map(list, zip(...)) # if you want lists isntead of tuples
答案 1 :(得分:1)
而不是
target = [url.strip() for url in f.readlines()]
使用
pairs = [line.strip().split(' | ') for line in f.readlines()]
target = [pair[0] for pair in pairs]
name = [pair[1] for pair in pairs]
答案 2 :(得分:1)
您是否需要不同变量中的所有名称和所有目标,例如:
In [1]:
with open("link123.txt") as f:
targets, names = zip(*[url.strip().split(' | ') for url in f])
targets, names
Out[1]:
(('www.link1.com', 'www.link2.com', 'www.link3.com'),
('linkname1', 'linkname2', 'linkname3'))
但你可能想考虑把它们放在一个字典中:
In [2]
with open("link123.txt") as f:
data = [dict(zip(['target', 'name'], url.strip().split(' | '))) for url in f]
data
Out[2]:
[{'name': 'linkname1', 'target': 'www.link1.com'},
{'name': 'linkname2', 'target': 'www.link2.com'},
{'name': 'linkname3', 'target': 'www.link3.com'}]