欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺析Python迭代器的高級用法

 更新時間:2020年07月16日 14:11:19   作者:TechFlow2019  
這篇文章主要介紹了Python迭代器的高級用法,在實際場景當中非常實用,可以幫助我們大大簡化代碼的復(fù)雜度。感興趣的朋友可以了解下

跳過開頭

首先是跳過開始部分,這個在我們讀取文本的時候最常用。在實際的應(yīng)用當中,比如記錄的日志或者是代碼等等,一般來說頭部都會附上一段說明,或者用注釋標注或者是用特殊的符號標記。這些信息是給用到數(shù)據(jù)的程序員看的,當我們通過代碼獲取數(shù)據(jù)的時候,顯然是希望可以過濾掉這些信息的。

比如我們有一段數(shù)據(jù),它的開頭用#做了一些注釋:

# This is a data for student
# Rows 100

xiaoming, 17, 99;
xiaoli, 18, 98;
...

常規(guī)操作當中,我們會創(chuàng)建一個打開文件的迭代器,我們通過遍歷這個迭代器去獲取文件當中的數(shù)據(jù):

with open('xxxx.txt') as f:
  for line in f:
    print(line)

如果只是用來輸出還好,如果我們需要加工文件當中的數(shù)據(jù),那么頭部的注釋信息就會干擾我們代碼的運行。我們當然可以手動加入一些判斷,但是這會比較麻煩,代碼也不夠美觀。針對這個問題,一個比較好的解決方案是dropwhile。

dropwhile是itemtools當中的一個函數(shù),它可以接收一個我們自定義的過濾函數(shù)和迭代器重新生成一個新的迭代器,這個新的迭代器當中會過濾掉之前迭代器頭部不符合我們要求的數(shù)據(jù):

在剛才的例子當中我們想要過濾掉頭部加了#注釋的部分,我們可以這么操作:

from itertools import dropwhile
with open('xxxx.txt') as f:
  for line in dropwhile(lambda line: line.startswith('#'), f):
    print(line)

這樣出來的結(jié)果就沒有頭部我們不需要的內(nèi)容了。

當我們知道頭部不符合情況的數(shù)據(jù)的格式的時候,可以使用dropwhile來規(guī)定過濾的格式。如果我們知道需要過濾的條數(shù),則可以使用另外一個工具,叫做islice,它的本質(zhì)是一個切片函數(shù),就像是Python當中數(shù)組的切片功能一樣,可以切出迭代器當中指定片段的數(shù)據(jù)。

舉個例子:

from itertools import dropwhile
with open('xxxx.txt') as f:
  for line in islice(f, 3, None):
    print(line)

這樣我們就會從第三行開始獲取,之前的數(shù)據(jù)會被過濾掉。它其實就代表著數(shù)組當中[3: ]的切片操作。

迭代排列組合

我們都知道在C++當中有一個叫做next_permutation的函數(shù),可以傳入一個數(shù)組,返回下一個字典序的排列。在Python當中也有同樣的功能,但是是以迭代器的形式使用的。

舉個簡單的例子,比如我們有a, b, c三個元素,我們希望求出它的所有排列:

items = ['a', 'b', 'c']
from itertools import permutations

for p in permutations(items):
  print(p)

permutations還支持多傳一個參數(shù),比如上述的排列當中我們希望只保留前兩個元素,除了切片之外,我們只需要多傳一個參數(shù)就好了,like this:

for p in permutations(items, 2):
  print(p)

除了排列之外,itertools當中還支持組合,用法還是一樣,只是把函數(shù)名稱換成是combinations而已:

from itertools import combindations
for c in combinations(items):
  print(c)

在一般的組合當中,一個元素一旦被選中那么它接下來就會從候選集當中移除,再也不會被選中。如果我們希望獲得有放回的組合,我們可以再換一個函數(shù),這個函數(shù)名稱有點長,但是名字倒也直觀叫做combinations_with_replacement。但既然是有放回的抽樣,我們需要設(shè)定元素的數(shù)量,否則抽樣可以無限進行下去。

for c in combinations_with_replacement(items, 3):
  print(c)

迭代合并后的序列

上一篇文章當中我們介紹了zip可以同時迭代多個迭代器,除此之外還有一種情況是我們需要把多個迭代器串起來迭代。比如系統(tǒng)的日志打在了多個文件當中,我們希望找出其中有error的日志來分析。這個時候,我們希望的不是同時讀取多個迭代器,而是希望能夠有辦法將多個迭代器的內(nèi)容串聯(lián)起來。這個功能就是itertools當中的chain方法,它接受多個迭代器,當我們遍歷的時候,會自動將多個迭代器的內(nèi)容串聯(lián)起來,我們可以無縫迭代。

舉個例子:

from itertools import chain
nums = [1, 2, 3]
chars = ['a', 'b', 'c']

for i in chain(nums, chars):
  print(i)

這樣我們會把nums和chars當中的內(nèi)容一起輸出出來,就好像從頭到尾只執(zhí)行了一個迭代器一樣。

你可能會說我們不用chain也可以實現(xiàn)啊,我們可以這樣:

for i in nums + chars:
  print(i)

的確,從結(jié)果上來看這樣也是行得通的。但是如果我們分析一下內(nèi)部執(zhí)行的時候的中間變量,會發(fā)現(xiàn)當我們執(zhí)行nums+chars的時候,實際上是先創(chuàng)建了一個新的臨時list。然后在這個list當中存儲nums和chars的數(shù)據(jù),也就是說我們迭代的其實是這個新的list。這帶來的結(jié)果是我們額外開辟了一段內(nèi)存,并且花費了一些時間。如果我們使用chain,它并不會有這樣的中間變量,完全是通過迭代器來執(zhí)行的迭代,非常節(jié)省內(nèi)存,這也是chain的優(yōu)點。

歸并迭代的內(nèi)容

對于歸并操作我們應(yīng)該都不陌生,在之前的歸并排序以及一些題解的文章當中我們見過很多次。同樣,我們在使用工具合并多個迭代器內(nèi)容的時候,如果迭代器當中的內(nèi)容有序,我們也可以對多個迭代器當中的元素進行歸并,而不再需要我們自己手動操作。

使用我們之前介紹的heapq的庫可以非常輕松地做到這一點,我們一起來看一個例子:

a = [1, 3, 5]
b = [2, 4, 6]

import heapq

for c in heapq.merge(a, b):
  print(c)

執(zhí)行之后,我們會得到[1, 2, 3, 4, 5, 6]的結(jié)果。也就是說通過heapq.merge操作,我們把多個有序的迭代器合并到了一起。當然我們也可以自己合并,但如果我們只是需要利用當中的數(shù)據(jù)的話,使用merge操作可以節(jié)省內(nèi)存空間。

到這里內(nèi)容就結(jié)束了,本文和之前的文章基本上列舉完了常用的迭代器用法。當然,除了上述講到的內(nèi)容之外,Python當中的迭代器還有一些其他的用法,不過相對不太常用,感興趣的同學(xué)可以私下了解。

以上就是淺析Python迭代器的高級用法的詳細內(nèi)容,更多關(guān)于Python迭代器的高級用法的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python中執(zhí)行MySQL結(jié)果限制和分頁查詢示例詳解

    Python中執(zhí)行MySQL結(jié)果限制和分頁查詢示例詳解

    這篇文章主要為大家介紹了Python中執(zhí)行MySQL結(jié)果限制和分頁查詢示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Python?time時間格式化操作指南

    Python?time時間格式化操作指南

    這篇文章主要給大家介紹了關(guān)于Python?time時間格式化操作的相關(guān)資料,Python中日期格式化是非常常見的操作,Python中能用很多方式處理日期和時間,轉(zhuǎn)換日期格式是一個常見的功能,需要的朋友可以參考下
    2023-10-10
  • 用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程

    用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程

    這篇文章主要介紹了用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程,包括單位格式轉(zhuǎn)換、分類匯總等基本操作,需要的朋友可以參考下
    2015-03-03
  • 詳解Python字符串原理與使用的深度總結(jié)

    詳解Python字符串原理與使用的深度總結(jié)

    本文將學(xué)習(xí)字符串數(shù)據(jù)類型相關(guān)知識,將討論如何聲明字符串數(shù)據(jù)類型,字符串數(shù)據(jù)類型與?ASCII?表的關(guān)系,字符串數(shù)據(jù)類型的屬性,以及一些重要的字符串方法和操作,超級干貨,不容錯過
    2022-05-05
  • PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗QRegExp實現(xiàn)

    PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗QRegExp實現(xiàn)

    這篇文章主要介紹了PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗QRegExp實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Python報錯KeyError: ‘missing_key‘的有效解決方法

    Python報錯KeyError: ‘missing_key‘的有效解決方法

    在 Python 編程中,報錯信息常常讓開發(fā)者感到困擾,其中,“KeyError: ‘missing_key’”是一個較為常見的報錯,它可能在各種數(shù)據(jù)處理和字典操作的場景中出現(xiàn),本文將深入探討這個報錯的原因,并提供多種有效的解決方法,幫助開發(fā)者快速解決此類問題
    2024-10-10
  • python 詳解如何使用GPU大幅提高效率

    python 詳解如何使用GPU大幅提高效率

    CuPy是一個開源矩陣庫,使用NVIDIA CUDA加速。CuPy使用Python提供GPU加速計算。CUPY使用CUDA相關(guān)庫,包括 CuBLAS、CUDNN、Curand、CuoSver、CuPaSeSE、Cufft和NCCL,以充分利用GPU架構(gòu)
    2021-11-11
  • Python操作MongoDB數(shù)據(jù)庫的方法示例

    Python操作MongoDB數(shù)據(jù)庫的方法示例

    這篇文章主要介紹了Python操作MongoDB數(shù)據(jù)庫的方法,結(jié)合實例形式分析了Python命令行模式下操作MongoDB數(shù)據(jù)庫實現(xiàn)連接、查找、刪除、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • Python優(yōu)雅實現(xiàn)二分查找的示例詳解

    Python優(yōu)雅實現(xiàn)二分查找的示例詳解

    二分查找是一種高效的搜索算法,用于在有序數(shù)組中查找特定元素,本文將介紹二分查找的基本原理,并通過Python代碼進行詳細講解,需要的可以參考一下
    2023-07-07
  • 將python包發(fā)布到PyPI和制作whl文件方式

    將python包發(fā)布到PyPI和制作whl文件方式

    今天小編就為大家分享一篇將python包發(fā)布到PyPI和制作whl文件方式,具有很的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12

最新評論