一、zip(*iterables)是内建函数 
它将返回一个元组迭代器,其中 i-th 元组将包含传入的每个迭代器中的 i-th 元素。一旦最短的输入迭代用完,该迭代器将停止 。
将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。
传入参数:元组、列表、字典等迭代器。
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以将元组解压为列表。
1、没有参数,则返回的是空列表
- zz=zip()
- print(zz,type(zz))
- print(list(zz))

2、有一个参数,则返回的是每一个元组组成的列表。
- num = [11, 22, 33,44,55]
- zz= zip(num)
- print(list(zz))

3、有多个参数,则返回的是对应的元组组成的列表。
- names = ['zhang', 'wang', 'li', 'yang']
- ages = [18,20, 22, 19]
- print(list(zip(names, ages)))

4、如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同
- zz =list(zip(range(3), 'ABCDEF'))
- print(zz)

5、可以并行迭代多个iterable,并使用循环输出信息
- names = ['zhang', 'wang', 'li', 'yang']
- ages = [18,20, 22, 19]
-
- for name,age in zip(names,ages):
- print(name,age)

并行迭代多个iterable,做加减乘除运算。
- num1 = [10, 20, 30,5]
- num2 = [5, 6, 5,8]
- operators = ['+', '-', '/','*']
- for n1,op,n2 in zip(num1,operators,num2):
- print(f'{n1}{op}{n2}={eval(str(n1)+op+str(n2))}')

6、可以同时遍历多个字典的数据
- done = {'name': 'Mike', 'last_name': 'Wei', 'job': 'Python'}
- dtwo = {'name': 'Sanse', 'last_name': 'Doe', 'job': 'Manager'}
- for (k1,v1),(k2,v2) in zip(done.items(),dtwo.items()):
- print(k1,v1)
- print(k2,v2)
7、将两个列表中的数据构建成列表再进行排序
- names = ['zhang', 'wang', 'li', 'yang']
- ages = [18,20, 22, 19]
- data = list(zip(names, ages))
- print(data)
- #根据字母升序排序
- data.sort()
- print(data)

8、可以使用 sorted() 和 zip() 一起使用来进行升序排序:
- names = ['zhang', 'wang', 'li', 'yang']
- ages = [18,20, 22, 19]
- data = sorted(zip(names, ages))
- print(data)

9、将两个列表中的数据构建成字典
- names = ['zhang', 'wang', 'li', 'yang']
- ages = [18,20, 22, 19]
- stu = dict(zip(names, ages))
- print(stu)
![]()
10、利用 * 号操作符,可以将列表解压为元组。
- names = ['zhang', 'wang', 'li', 'yang']
- ages = [18,20, 22, 19]
- # 转换为列表
- print(list(zip(names,ages)))
-
- # 解压
- n,a=zip(*zip(names,ages))
- print(n)
- print(a)
