python中zip用法:并行遍历
python中内置的zip函数可以让我们使用for来进行多个序列的遍历。例如:
L1 = [1,2,3,4]
L2 = [5,6,7,8]
lis = list(zip(L1,L2))
print(lis)
>>>[(1,5),(2,6),(3,7),(4,8)]
for (x,y) in zip(L1,L2):
print(x,y,"=",x+y)
>>>
1 5 = 6
2 6 = 8
3 7 = 10
...
...
...
上例1中,zip创建元组对存放到列表中。例2中使用for来遍历元组对。也就是说在循环中扫描了L1和L2。
这里我们初步认识了zip函数。我们更深入的来看zip:
- zip可接受任何类型的序列(可迭代对象),包括文件类型。但需要注意的是,zip()中的两个参数都必须是相同的序列对象,要么都是列表,要么都是字符串等。
- zip可以有两个以上的参数。比如:
L1 = [1,2,3,4]
L2 = [5,6,7,8]
L3 = [4,3,2,1]
list(zip(L1,L2,L3))
>>>[(1,5,4),(2,6,3),(3,7,2),(4,8,1)]
- 当两个序列的参数长度不同时,zip以最短的序列来截断。比如:
L1 = [a,b,c]
L2 = [1,2,3,4]
list(zip(L1,L2))
>>>[(a,1),(b.2),(c,3)]
- 可以使用zip构造字典
keys = ['name','age','job']
vals = ['ww',23,'student']
d = dict(zip(keys,vals))
>>>{'name' : 'ww', 'age' : 23, 'job' : 'student'}