Python同時迭代多個序列的方法
問題
你想同時迭代多個序列,每次分別從一個序列中取一個元素。
解決方案
為了同時迭代多個序列,使用 zip() 函數(shù)。比如:
>>> xpts = [1, 5, 4, 2, 10, 7] >>> ypts = [101, 78, 37, 15, 62, 99] >>> for x, y in zip(xpts, ypts): ... print(x,y) ... 1 101 5 78 4 37 2 15 10 62 7 99 >>>
zip(a, b) 會生成一個可返回元組 (x, y) 的迭代器,其中x來自a,y來自b。一旦其中某個序列到底結(jié)尾,迭代宣告結(jié)束。因此迭代長度跟參數(shù)中最短序列長度一致。
>>> a = [1, 2, 3] >>> b = ['w', 'x', 'y', 'z'] >>> for i in zip(a,b): ... print(i) ... (1, 'w') (2, 'x') (3, 'y') >>>
如果這個不是你想要的效果,那么還可以使用 itertools.zip_longest() 函數(shù)來代替。比如:
>>> from itertools import zip_longest >>> for i in zip_longest(a,b): ... print(i) ... (1, 'w') (2, 'x') (3, 'y') (None, 'z')
>>> for i in zip_longest(a, b, fillvalue=0): ... print(i) ... (1, 'w') (2, 'x') (3, 'y') (0, 'z') >>>
討論
當你想成對處理數(shù)據(jù)的時候 zip() 函數(shù)是很有用的。比如,假設(shè)你頭列表和一個值列表,就像下面這樣:
headers = ['name', 'shares', 'price'] values = ['ACME', 100, 490.1]
使用zip()可以讓你將它們打包并生成一個字典:
s = dict(zip(headers,values))
或者你也可以像下面這樣產(chǎn)生輸出:
for name, val in zip(headers, values): print(name, '=', val)
雖然不常見,但是 zip() 可以接受多于兩個的序列的參數(shù)。這時候所生成的結(jié)果元組中元素個數(shù)跟輸入序列個數(shù)一樣。比如;
>>> a = [1, 2, 3] >>> b = [10, 11, 12] >>> c = ['x','y','z'] >>> for i in zip(a, b, c): ... print(i) ... (1, 10, 'x') (2, 11, 'y') (3, 12, 'z') >>>
最后強調(diào)一點就是,zip() 會創(chuàng)建一個迭代器來作為結(jié)果返回。如果你需要將結(jié)對的值存儲在列表中,要使用 list() 函數(shù)。比如:
>>> zip(a, b) <zip object at 0x1007001b8> >>> list(zip(a, b)) [(1, 10), (2, 11), (3, 12)] >>>
以上就是Python同時迭代多個序列的方法的詳細內(nèi)容,更多關(guān)于Python同時迭代多個序列的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python列表插入append(), extend(), insert()用法詳解
在本篇文章里小編給大家整理了關(guān)于python列表插入append(), extend(), insert()用法以及相關(guān)知識點,有需要的朋友們參考下。2019-09-09
python web基礎(chǔ)之加載靜態(tài)文件實例
下面小編就為大家分享一篇python web基礎(chǔ)之加載靜態(tài)文件實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
用python實現(xiàn)學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細介紹了用python實現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07
python web自制框架之接受url傳遞過來的參數(shù)實例
今天小編就為大家分享一篇python web自制框架之接受url傳遞過來的參數(shù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12

