中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

大數據開發中itertools.chain()函數怎么用

發布時間:2021-12-15 15:15:35 來源:億速云 閱讀:200 作者:小新 欄目:大數據

這篇文章主要介紹了大數據開發中itertools.chain()函數怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

你想在多個對象執行相同的操作,但是這些對象在不同的容器中,你希望代碼在不失可讀性的情況下避免寫重復的循環

from itertools import chain 
a = [1, 2, 3, 4] 
b = ['x', 'y', 'z'] 
for x in chain(a, b): 
    print(x) 
1 
2 
3 
4 
x 
y 
z

好處:如果采用a+b的方式遍歷,那么要求a和b的類型一致,如果數據再大一點會,會消耗內存,而chain是通過創建迭代器,依次返回可迭代對象的元素

如何把一個 itertools.chain 對象轉換為一個數組

list_of_numbers = [[1, 2], [3], []]
import itertools
chain = itertools.chain(*list_of_numbers)

第一種比較簡單,直接采用 list 方法,如下所示:

list(chain)

但缺點有兩個:

  • 會在外層多嵌套一個列表

  • 效率并不高

第二個就是利用 numpy 庫的方法 np.fromiter ,示例如下:

>>> import numpy as np
>>> from itertools import chain
>>> list_of_numbers = [[1, 2], [3], []]
>>> np.fromiter(chain(*list_of_numbers), dtype=int)
array([1, 2, 3])

對比兩種方法的運算時間,如下所示:

>>> list_of_numbers = [[1, 2]*1000, [3]*1000, []]*1000
>>> np.fromiter(chain(*list_of_numbers), dtype=int)
10 loops, best of 3: 103 ms per loop
>>> np.array(list(chain(*list_of_numbers)))
1 loops, best of 3: 199 ms per loop

可以看到采用 numpy 方法的運算速度會更快。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“大數據開發中itertools.chain()函數怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

吕梁市| 资讯| 胶州市| 中西区| 台湾省| 乌鲁木齐县| 大余县| 大庆市| 扶沟县| 田阳县| 开封市| 彰化市| 松潘县| 永泰县| 资讯| 大新县| 鹿泉市| 三亚市| 随州市| 安国市| 衡阳县| 昌都县| 卢龙县| 扎鲁特旗| 威远县| 洛南县| 白沙| 彭阳县| 玛纳斯县| 甘德县| 大方县| 丹巴县| 永丰县| 万荣县| 宝鸡市| 自治县| 开封县| 乌恰县| 海宁市| 吐鲁番市| 宜阳县|