python zip()函數(shù)的使用示例
zip()函數(shù)將可迭代的對象作為參數(shù),將對象對應的元素打包成一個個元祖,然后返回由這些元祖組成的對象,我們可以使用list()轉換成列表
如果各個迭代器的元素個數(shù)不一致,則返回列表長度和最小的對象相同,用*好操作符,可以將元祖解壓為列表
1.兩個或者多個list
a=[1,2,3] b=[4,5,6] c=[7,8,9,10] #兩個list去zip() zip(a,b) #三個list去zip(),返回的對象的長度和最小的迭代器一致 zip(a,b,c) #用list()查看zip后的數(shù)據(jù) list(zip(a,b)) #[(1, 4), (2, 5), (3, 6)] list(zip(a,b,c)) #[(1, 4, 7), (2, 5, 8), (3, 6, 9)] #使用zip(*zip())解壓 a1,b1=zip(*zip(a,b)) #兩個list迭代輸出 for i,j in zip(a,b): print(i,j)
輸出:
1 4
2 5
3 6
2.如有兩個list,一個是一層,一個是嵌套,要組成一個dict
#將zip對象轉換成字典看看
a=[1,2,3]
d=[['a','b','c'],['aa','bb','cc'],['aaa','bbb','ccc']]
dict(zip(a,d)) #{1: ['a', 'b', 'c'], 2: ['aa', 'bb', 'cc'], 3: ['aaa', 'bbb', 'ccc']}
#如果一個是key值,一個內層list就是一行value
[dict(zip(a,value)) for value in d] #[{1: 'a', 2: 'b', 3: 'c'},
{1: 'aa', 2: 'bb', 3: 'cc'},
{1: 'aaa', 2: 'bbb', 3: 'ccc'}]
#或者是
l=[]
for value in d:
dict={}
for i in range(len(value)):
dict[a[i]]=value[i]
l.append(dict)
3.同時遍歷兩個dict
如果長度相同的dict直接用zip函數(shù)即可同時for
如果長度不同,可以先把這兩個dict整合進一個list再for
dict_1=dict(zip(a,b)) #{1: 4, 2: 5, 3: 6}
dict_2=dict(zip(a,d)) # {1: ['a', 'b', 'c'], 2: ['aa', 'bb', 'cc'], 3: ['aaa', 'bbb', 'ccc']}
#key的遍歷
for i,j in zip(dict_1,dict_2):
print(i,j)
輸出:
1 1
2 2
3 3
#values的遍歷 for i ,j in zip(dict_1.values(),dict_2.values()): print(i,j)
輸出:
4 ['a', 'b', 'c']
5 ['aa', 'bb', 'cc']
6 ['aaa', 'bbb', 'ccc']
#同時遍歷,需要2個dict的value都是多層的
dict_4=dict(zip(b,d)) #{4: ['a', 'b', 'c'], 5: ['aa', 'bb', 'cc'], 6: ['aaa', 'bbb', 'ccc']}
for i,j in zip(dict_4,dict_2):
for k in dict_4[i]:
print(i,k)
for m in dict_2[j]:
print(j,m)
輸出:
4 a
4 b
4 c
1 a
1 b
1 c
5 aa
5 bb
5 cc
2 aa
2 bb
2 cc
6 aaa
6 bbb
6 ccc
3 aaa
3 bbb
3 ccc
以上就是python zip()的使用示例的詳細內容,更多關于python zip()的資料請關注腳本之家其它相關文章!
相關文章
Python 序列化和反序列化庫 MarshMallow 的用法實例代碼
marshmallow(Object serialization and deserialization, lightweight and fluffy.)用于對對象進行序列化和反序列化,并同步進行數(shù)據(jù)驗證。這篇文章主要介紹了Python 序列化和反序列化庫 MarshMallow 的用法實例代碼,需要的朋友可以參考下2020-02-02
Python實現(xiàn)斐波那契數(shù)列的示例代碼
斐波那契數(shù)列是一種經典的數(shù)學問題,在計算機科學和編程中經常被用來演示算法和遞歸的概念,本文將詳細介紹斐波那契數(shù)列的定義、計算方法以及如何在Python中實現(xiàn)它,需要的可以參考下2024-01-01

