python進(jìn)階之自定義可迭代的類
自定義可迭代的類
列表可以獲取列表的長(zhǎng)度,然后使用變量i對(duì)列表索引進(jìn)行循環(huán),也可以獲取集合的所有元素,且容易理解。沒(méi)錯(cuò),使用列表的代碼是容易理解,也很好操作,但這是要付出代價(jià)的。列表之所以可以用索引來(lái)快速定位其中的任何一個(gè)元素,是因?yàn)榱斜硎且幌伦訉⑺械臄?shù)據(jù)都裝載在內(nèi)存中,而且是一塊連續(xù)的內(nèi)存空間。當(dāng)數(shù)據(jù)量比較小時(shí),實(shí)現(xiàn)比較容易;當(dāng)數(shù)據(jù)量非常大時(shí),會(huì)非常消耗內(nèi)存資源。而迭代就不同,迭代是讀取多少元素,就將多少元素裝載到內(nèi)存中,不讀取就不裝載。這有點(diǎn)像處理XML的兩種方式:DOM和SAX。DOM是一下子將所有的XML數(shù)據(jù)都裝載到內(nèi)存中,所以可以快速定位任何一個(gè)元素,但代價(jià)是消耗內(nèi)存;而SAX是順序讀取XML文檔,沒(méi)讀到的XML文檔內(nèi)容是不會(huì)裝載到內(nèi)存中的,所以SAX比較節(jié)省內(nèi)存,但只能從前向后的順序讀取XML文檔的內(nèi)容。
如果在一個(gè)類中定義__iter__方法,那么這個(gè)類的實(shí)例就是一個(gè)迭代器。 __iter__方法需要返回一個(gè)迭代器,所以就返回對(duì)象本身即可(也就是self)。當(dāng)對(duì)象每迭代一次時(shí),就會(huì)調(diào)用迭代器中的另外一個(gè)特殊成員方法__next__ 。該方法需要返回當(dāng)前迭代的結(jié)果。下面先看一個(gè)簡(jiǎn)單的例子,在這個(gè)例子中,通過(guò)自定義迭代器對(duì)由星號(hào)*組成的直三角形的每一行進(jìn)行迭代,然后通過(guò)for循環(huán)進(jìn)行迭代,輸出一定行數(shù)的直角三角形。
# 可無(wú)限迭代直角三角形的行
class righttriangle:
def __init__(self):
# 定義一個(gè)變量n,表示當(dāng)前的行數(shù)
self.n = 1
def __next__(self):
# 通過(guò)字符串的乘法獲取直接三角形每一行的字符串,每一行字符串的長(zhǎng)度是2 * n -1
result = '*' * (2 * self.n - 1)
# 行數(shù)加1
self.n += 1
return result
# 該方法必須返回一個(gè)迭代器
def __iter__(self):
return self
rt = righttriangle()
# 對(duì)迭代器進(jìn)行迭代
for e in rt:
# 限制輸出行的長(zhǎng)度不能大于20,否則將會(huì)無(wú)限輸出行
if len(e) > 20:
break
print(e)
輸出結(jié)果:
* *** ***** ******* ********* *********** ************* *************** ***************** *******************
[例10.10] 現(xiàn)在來(lái)看一個(gè)更有意思的例子,在這個(gè)例子中定義了一個(gè)迭代器類(Fibonacci),用于無(wú)限制迭代斐波那契數(shù)列。
# 可以無(wú)限制迭代斐波那契數(shù)列
class Fibonacci:
# 在構(gòu)造方法中定義兩個(gè)變量a和b,用來(lái)表示斐波那契數(shù)列的最開(kāi)始的兩個(gè)值
def __init__(self):
self.a = 0
self.b = 1
def __next__(self):
# self.a就是當(dāng)前要迭代的值
result = self.a
# 計(jì)算斐波那契數(shù)列的下一個(gè)值,并將a變成原來(lái)的b,將b變成下一個(gè)值
self.a, self.b = self.b, self.a + self.b
# 返回當(dāng)前迭代的值
return result
# 該方法必須返回一個(gè)迭代器
def __iter__(self):
return self
fibs = Fibonacci()
# 對(duì)斐波那契數(shù)列進(jìn)行迭代
for fib in fibs:
print(fib,end = ' ')
# 迭代的值不能超過(guò)500
if fib > 500:
break
輸出結(jié)果:
0 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
pytorch讀取圖像數(shù)據(jù)轉(zhuǎn)成opencv格式實(shí)例
這篇文章主要介紹了pytorch讀取圖像數(shù)據(jù)轉(zhuǎn)成opencv格式實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06
TensorFlow教程Softmax邏輯回歸識(shí)別手寫(xiě)數(shù)字MNIST數(shù)據(jù)集
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)的TensorFlow教程基于Softmax邏輯回歸識(shí)別手寫(xiě)數(shù)字的MNIST數(shù)據(jù)集示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-11-11
Python基礎(chǔ)之變量的相關(guān)知識(shí)總結(jié)
今天給大家?guī)?lái)的是關(guān)于Python的相關(guān)知識(shí),文章圍繞著Python變量展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06
python利用 pytesseract快速識(shí)別提取圖片中的文字((圖片識(shí)別)
本文介紹了tesseract的python調(diào)用,也就是pytesseract庫(kù),其中還有一些其他的內(nèi)容并沒(méi)有涉及,僅涉及到了圖片提取文字,如果你對(duì)其感興趣,可以深入探索一下,也希望能和我探討一下2022-11-11
Anaconda+VSCode配置tensorflow開(kāi)發(fā)環(huán)境的教程詳解
Anaconda是一個(gè)開(kāi)源的python發(fā)行版本,是現(xiàn)在比較流行的python數(shù)據(jù)科學(xué)平臺(tái),可以對(duì)python的科學(xué)包做到有效管理。這篇文章主要介紹了Anaconda+VSCode配置tensorflow開(kāi)發(fā)環(huán)境,需要的朋友可以參考下2020-03-03
解決nohup執(zhí)行python程序log文件寫(xiě)入不及時(shí)的問(wèn)題
今天小編就為大家分享一篇解決nohup執(zhí)行python程序log文件寫(xiě)入不及時(shí)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
Python利用imshow制作自定義漸變填充柱狀圖(colorbar)
這篇文章主要介紹了Python利用imshow制作自定義漸變填充柱狀圖(colorbar),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
在Python中關(guān)于使用os模塊遍歷目錄的實(shí)現(xiàn)方法
今天小編就為大家分享一篇在Python中關(guān)于使用os模塊遍歷目錄的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
Python Opencv任意形狀目標(biāo)檢測(cè)并繪制框圖
這篇文章主要為大家詳細(xì)介紹了Python Opencv任意形狀目標(biāo)檢測(cè),并繪制框圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07

