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 1015 784 372 1510 627 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)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 使用css實現(xiàn)全兼容tooltip提示框2. 前端html+css實現(xiàn)動態(tài)生日快樂代碼3. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)4. Vue3使用JSX的方法實例(筆記自用)5. JavaScript數(shù)據(jù)類型對函數(shù)式編程的影響示例解析6. 詳解CSS偽元素的妙用單標簽之美7. Vue3獲取DOM節(jié)點的3種方式實例8. 利用CSS3新特性創(chuàng)建透明邊框三角9. vue實現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細教程10. 不要在HTML中濫用div
