我需要打破对值的行并将其转换为列表或字典。有谁知道在 Python 中执行此操作的简单方法?
由此:
1
Petrov
2
Ivanov
3
Sidorov
至
["1", "Petrov"], ["2", "Ivanov"], ["3", "Sidorov"]
或字典:
{"1": "Petrov", "2": "Ivanov", "3": "Sidorov"}
我需要打破对值的行并将其转换为列表或字典。有谁知道在 Python 中执行此操作的简单方法?
由此:
1
Petrov
2
Ivanov
3
Sidorov
至
["1", "Petrov"], ["2", "Ivanov"], ["3", "Sidorov"]
或字典:
{"1": "Petrov", "2": "Ivanov", "3": "Sidorov"}
>>> strs = """1
Petrov
2
Ivanov
3
Sidorov"""
>>> dict(zip(*[iter(strs.splitlines())]*2))
{'2': 'Ivanov', '3': 'Sidorov', '1': 'Petrov'}
>>> strs = """1
Petrov
2
Ivanov
3
Sidorov"""
>>> i = iter(strs.split())
>>> {item: i.next() for item in i}
{'1': 'Petrov', '3': 'Sidorov', '2': 'Ivanov'}
或者
>>> i = iter(strs.split())
>>> [[item, i.next()] for item in i]
[['1', 'Petrov'], ['2', 'Ivanov'], ['3', 'Sidorov']]
通过操作列表中的奇数项和偶数项,为 hcwhsa 的解决方案添加了一点变化:
>>> s = "1\nPetrov\n2\nIvanov\n3\nSidorov"
>>> dict(zip(s.split("\n")[::2], s.split("\n")[1::2]))
{'1': 'Petrov', '3': 'Sidorov', '2': 'Ivanov'}
此代码将为您返回一个字典:
inp = open("file")
d = dict()
k = list()
v = list()
for line in inp:
if line.strip("\n").isdigit():
k.append(line.strip("\n"))
else:
v.append(line.strip("\n"))
print dict(zip(k,v))