久久er99热精品一区二区三区,波多野结衣在线观看一区二区 ,成人做爰视频www网站小优视频,在线免费福利

二維碼
企資網

掃一掃關注

當前位置: 首頁 » 企業資訊 » 經驗 » 正文

Python_中的迭代器實現原理是什么?

放大字體  縮小字體 發布日期:2023-03-10 11:48:36    作者:葉麓菲    瀏覽次數:141
導讀

本文首發自「慕課網」,想了解更多IT干貨內容,程序員圈內熱聞,歡迎關注!作者| 慕課網精英講師 朱廣蔚在數學中,集合表示由一個或多個確定的元素所構成的整體。在 Python 中,列表、元組、集合可以用于表示數學中

本文首發自「慕課網」,想了解更多IT干貨內容,程序員圈內熱聞,歡迎關注!

作者| 慕課網精英講師 朱廣蔚

在數學中,集合表示由一個或多個確定的元素所構成的整體。在 Python 中,列表、元組、集合可以用于表示數學中的集合。

例如,分別使用列表、元組、集合表示了一個包含 3 個字符串的集合:

  • 列表 [‘www’, ‘imooc’, ‘com’]
  • 元組 (‘www’, ‘imooc’, ‘com’)
  • 集合 {‘www’, ‘imooc’, ‘com’}1. 可迭代對象 iterable1.1 什么是可迭代對象

    Python 提供了 for … in 循環,用于對列表、元組、集合中的元素進行遍歷。能夠被 for … in 循環遍歷的對象被稱為可迭代對象 iterable,列表、元組、集合均屬于可迭代對象。使用 for … in 循環遍歷可迭代對象的例子如下:

  • 遍歷列表的代碼

    list = ['www', 'imooc', 'com']for item in list: print(item)代碼塊123

  • 遍歷元組的代碼

    tuple = ('www', 'imooc', 'com')for item in tuple: print(item)代碼塊123

  • 遍歷集合的代碼

    set = {'www', 'imooc', 'com'}for item in set: print(item)代碼塊1231.2 盡可能使用 for … in 循環進行遍歷

    如果需要遍歷的對象是列表,可以通過訪問索引的方式進行遍歷,代碼如下:

    strings = ['www', 'imooc', 'com']i = 0while i < len(strings): string = strings[i] print(string) i = i + 1代碼塊123456

  • 在第 1 行,使用列表表示 strings
  • 在第 3 行,通過 len(strings) 獲取列表 strings 中字符串的數量
  • 在第 4 行,通過 strings[i] 訪問第 i 個元素

    以上的遍歷方式中,要求 strings 是一個列表,如果 strings 的數據結構發生變化:使用集合而不是列表表示 strings,那么通過訪問索引的方式進行遍歷的代碼就會失效。

    strings = {'www', 'imooc', 'com'}i = 0while i < len(strings): string = strings[i] print(string) i = i + 1代碼塊123456

  • 在第 1 行,使用集合表示 strings
  • 在第 3 行,通過 len(strings) 獲取集合 strings 中字符串的數量
  • 在第 4 行,通過 strings[i] 訪問第 i 個元素

    因為 strings 是一個集合,不支持索引操作,會導致運行錯誤:

    Traceback (most recent call last): File "strings.py", line 5, in <module> string = strings[i]TypeError: 'set' object does not support indexing代碼塊1234

    應盡可能使用 for … in 循環遍歷可迭代對象,如果可迭代對象的數據類型發生變化,從列表變成集合,使用for … in 循環遍歷的代碼則無需改變。

    2. 迭代器 iterator1.1 什么是迭代器

    迭代器 iterator 是一個特殊的對象,用于遍歷訪問可迭代對象 iterable。Python 通過迭代器 iterator 實現 for … in 循環語句,用戶編寫的 for … in 循環代碼如下:

    for item in iterable: print(item)代碼塊12

    這段 for … in 循環代碼會被翻譯為如下:

    iterator = iter(iterable)while True: try: item = next(iterator) print(item) except StopIteration: break代碼塊1234567

  • 在第 1 行,內置函數 iter 獲取可迭代對象 iterable 的迭代器 iterator
  • 在第 4 行,內置函數 next 獲取迭代器 iterator 返回的下一個元素
  • 在第 6 行,當迭代器遍歷完全部元素后,拋出一個特殊的異常 StopIteration,表示迭代結束1.2 列表的迭代器

    下面通過一個具體的例子,了解如何通過迭代器實現 for … in 循環,使用 for … in 循環遍歷列表的代碼如下:

    list = ['www', 'imooc', 'com']for item in list: print(item)代碼塊123

    Python 把以上 for … in 循環轉換為如下功能等價的代碼:

    list = ['www', 'imooc', 'com']listIterator = iter(list)while True: try: item = next(listIterator) print(item) except StopIteration: break代碼塊12345678

    以上兩段代碼均輸出相同的結果,如下所示:

    wwwimooccom代碼塊1233. 迭代協議

    使用迭代器遍歷訪問可迭代對象,要求迭代器和可迭代對象遵循迭代協議,迭代協議如下:

    1. 可迭代對象 iterable 提供成員方法 __iter__,該方法返回用于遍歷的迭代器 iterator

    class Iterable: def __iter__(self):代碼塊12

    1. 迭代器 iterator 提供成員方法 __next__,該方法返回下一個被遍歷的元素

    class Iterator: def __next__(self):代碼塊12

    1. 異常 StopIteration,當遍歷完全部的元素后,成員方法 __next__ 拋出一個特殊的異常 Stop Iteration 表示遍歷結束
    2. 內置函數 iter,用于獲取可迭代對象對應的迭代器

    def iter(iterable): iterator = iterable.__iter__() return iterator代碼塊123

  • 在第 1 行,iter 的輸入參數是可迭代對象 iterable
  • 在第 2 行,調用成員方法 __iter__
  • 在第 3 行,返回迭代器 iterator
    1. 內置函數 next,用于獲取下一個被遍歷的元素

    def next(iterator): item = iterator.__next__() return item代碼塊123

  • 在第 1 行,next 的輸入參數是迭代器 iterator
  • 在第 2 行,調用成員方法 __next__
  • 在第 3 行,返回被遍歷的元素

    根據以上的迭代協議,即可將 for … in 循環翻譯為如下等價代碼:

    iterator = iter(iterable)while True: try: item = next(iterator) print(item) except StopIteration: break代碼塊12345674. 實現一個自定義的迭代器4.1 通過單鏈表實現堆棧

    通過單鏈表實現堆棧,圖示如下:

    通過單鏈表實現堆棧

    在上圖中,每個節點有兩個字段: item 和 next,item 用于存儲數據,next 指向下一個節點,head 指針指向堆棧的頂部。描述堆棧的 Python 代碼如下:

    class Node: def __init__(self, item): self.item = item self.next = Noneclass Stack: def __init__(self): self.head = None def push(self, item): node = Node(item) node.next = self.head self.head = nodestack = Stack()stack.push('a')stack.push('b')stack.push('c')代碼塊123456789101112131415161718

  • 在第 1 行,定義了類 Node 用于描述鏈表中的節點
  • 在第 6 行,定義了類 Stack 描述堆棧在第 8 行,定義了頭指針 head,指向鏈表中的首個節點在第 10 行,定義了成員方法 push,將元素壓如到堆棧中在第 11 行,創建一個新節點 node在第 12 行,新節點 node 的 next 指向頭結點在第 13 行,頭結點指向新節點
  • 在第 15 行,創建一個對象 stack
  • 在第 16 行到第 18 行,依次壓入 3 個元素 ‘a’、‘b’、‘c’4.2 實現迭代協議

    class StackIterator: def __init__(self, stack): self.stack = stack self.cursor = self.stack.head def __next__(self): if self.cursor == None: raise StopIteration else: item = self.cursor.item self.cursor = self.cursor.next return item代碼塊123456789101112

  • 在第 1 行,定義類 StackIterator類 Stack 是可迭代對象類 StackIterator 是迭代器
  • 在第 2 行,定義構造函數,參數 stack 是被遍歷的對象在第 4 行,成員變量 cursor 指向了當前正在遍歷的元素,初始化被設置為鏈表的頭結點
  • 在第 6 行,定義方法 __next__在第 7 行,如果變量 cursor 等于 None,表示已經到達鏈表的尾部,即遍歷完全部的元素了在第 8 行,拋出異常 StopIteration 表示遍歷結束在第 9 行,如果變量 cursor 不等于 None在第 10 行,記錄下當前正在遍歷的元素在第 11 行,將 cursor 指向下一個元素

    在定義了 StackIterator 后,在 Stack 中增加一個新的成員方法 __iter__,返回 Stack 對應的迭代器,代碼如下:

    class Stack: def __iter__(self): return StackIterator(self) 代碼塊1234.3 通過 while 循環遍歷堆棧

    在實現了迭代協議后,使用 while 循環顯示的使用 iter、next、StopIteration 完成對 stack 的遍歷,代碼如下:

    stackIterator = iter(stack)while True: try: item = next(stackIterator) print(item) except StopIteration: break代碼塊1234567

    程序依次壓入 ‘a’、‘b’、‘c’,遍歷時以壓入相反的順序輸出,結果如下:

    cba代碼塊1234.4 通過 for … in 循環遍歷堆棧

    在實現了迭代協議后,可以通過 for … in 循環進行遍歷,代碼如下:

    for item in stack: print(item)代碼塊12

    與上一節的代碼相比,代碼要簡潔很多,程序輸出相同的結果如下:

    cba代碼塊123

    歡迎關注「慕課網」,發現更多IT圈優質內容,分享干貨知識,幫助你成為更好的程序員!

  •  
    (文/葉麓菲)
    免責聲明
    本文僅代表作發布者:葉麓菲個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
     

    Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

    粵ICP備16078936號

    微信

    關注
    微信

    微信二維碼

    WAP二維碼

    客服

    聯系
    客服

    聯系客服:

    在線QQ: 303377504

    客服電話: 020-82301567

    E_mail郵箱: weilaitui@qq.com

    微信公眾號: weishitui

    客服001 客服002 客服003

    工作時間:

    周一至周五: 09:00 - 18:00

    反饋

    用戶
    反饋

    久久er99热精品一区二区三区,波多野结衣在线观看一区二区 ,成人做爰视频www网站小优视频,在线免费福利
    欧美日韩亚洲另类| 国产原创一区二区| 欧美色区777第一页| 欧美日韩在线播| 亚洲欧美偷拍三级| 欧美裸体一区二区三区| 一区二区三区久久| 国产很黄免费观看久久| 国产成人午夜片在线观看高清观看| 在线观看日韩电影| 激情文学综合网| 久久综合久久99| 成人激情黄色小说| 亚洲欧洲日本在线| 欧美午夜一区二区| 91精品蜜臀在线一区尤物| 欧美精品一卡两卡| 色综合久久久久综合| 不卡电影免费在线播放一区| 日韩电影免费在线看| 久久精品国产网站| 日韩精品成人一区二区在线| jizzjizzjizz欧美| 综合久久综合久久| 69久久夜色精品国产69蝌蚪网| 欧美专区在线观看一区| 午夜视频一区二区三区| 亚洲特黄一级片| 不卡高清视频专区| 国内精品伊人久久久久影院对白| 欧美日韩久久久| 日韩欧美在线综合网| 国产日韩欧美一区二区三区综合| 国产日产欧美精品一区二区三区| 国产精品女人毛片| 91麻豆自制传媒国产之光| 国产不卡视频一区| 欧美一区二区三区四区高清| 久久久久久一二三区| 亚洲一区影音先锋| 国产成人av网站| 欧美久久久久久久久中文字幕| 五月开心婷婷久久| 日韩视频一区二区三区在线播放| 97精品久久久午夜一区二区三区 | 欧美精品一区二区久久久| 日本精品一区二区三区高清 | 欧美精品一区二区精品网| 精品福利视频一区二区三区| 国产精品高潮呻吟| 人妖欧美一区二区| 色视频成人在线观看免| 欧美激情中文字幕一区二区| 国产精品乱码妇女bbbb| 成人免费看片app下载| 久久99精品久久久久久动态图| 天天爽夜夜爽夜夜爽精品视频| 爽好久久久欧美精品| 精品在线亚洲视频| av一区二区三区| 欧美性猛交xxxx乱大交退制版| 欧美剧情电影在线观看完整版免费励志电影 | 国产丶欧美丶日本不卡视频| 国产精品久久99| 欧美一区二区高清| 色婷婷av久久久久久久| 亚洲免费高清视频在线| 欧美成人免费网站| 色94色欧美sute亚洲线路一久| 国产日韩欧美精品电影三级在线| 亚洲欧美经典视频| 欧美三级视频在线观看| 欧美极品另类videosde| 美女免费视频一区二区| 日本系列欧美系列| 一区二区三区在线播放| 一区二区三区四区亚洲| 91视频免费播放| a4yy欧美一区二区三区| 一本大道久久精品懂色aⅴ| 日韩欧美中文字幕公布| 亚洲一区二区三区美女| 亚洲人成7777| 亚洲一区二区三区中文字幕在线| 国产一区二区三区日韩 | 欧美激情中文字幕一区二区| 亚洲人成网站影音先锋播放| 麻豆91精品视频| 免费在线观看日韩欧美| 日韩电影一二三区| 久久影视一区二区| 久久日韩精品一区二区五区| 国产精品综合av一区二区国产馆| 欧美日韩aaaaaa| 欧美日本国产视频| 欧美激情在线观看视频免费| 久久99国产精品久久99| 欧美三级日韩三级| 亚洲mv大片欧洲mv大片精品| 91网站最新网址| 久久精品国产精品亚洲精品| 欧美日韩在线精品一区二区三区激情| 久久久久久**毛片大全| 首页亚洲欧美制服丝腿| 欧美一级精品在线| 日韩高清不卡一区二区三区| 91麻豆精品国产91久久久资源速度 | 国产色产综合色产在线视频| 国产精品一二三区在线| 国产精品美女久久久久av爽李琼| 一本到一区二区三区| 美女一区二区三区在线观看| 国产欧美精品日韩区二区麻豆天美| 色爱区综合激月婷婷| 久久久精品国产免大香伊 | 国产精品视频观看| 欧美一区二区在线不卡| 91在线视频在线| 激情五月婷婷综合| 图片区日韩欧美亚洲| 国产精品久久久久久久午夜片| 欧美一区二区三区白人| 91麻豆精东视频| 国产成人免费高清| 麻豆精品视频在线| 亚洲国产精品久久不卡毛片| 国产一区欧美一区| 日本不卡在线视频| 洋洋av久久久久久久一区| 亚洲国产精品成人综合色在线婷婷 | 欧美一区在线视频| 欧美性猛交xxxx乱大交退制版 | 在线电影一区二区三区| 色综合久久九月婷婷色综合| 国产福利一区在线观看| 经典三级一区二区| 777色狠狠一区二区三区| 日本二三区不卡| 91在线一区二区| 91美女片黄在线观看91美女| 国产乱淫av一区二区三区| 久久99久久99小草精品免视看| 丝袜美腿高跟呻吟高潮一区| 亚洲国产美女搞黄色| 亚洲一区二区四区蜜桃| 亚洲色图色小说| 亚洲欧美综合色| 亚洲免费在线观看视频| 亚洲免费观看高清完整版在线观看熊 | 久久久另类综合| 久久精品人人爽人人爽| 国产亚洲精品久| 国产精品毛片大码女人| 日韩理论片一区二区| 亚洲男人电影天堂| 一区二区成人在线观看| 亚洲一二三区视频在线观看| 亚洲在线一区二区三区| 三级久久三级久久| 久久爱www久久做| 国产精品综合二区| 91亚洲永久精品| 欧美三级韩国三级日本三斤| 日韩一级免费一区| 精品国产乱码久久久久久夜甘婷婷| 久久人人97超碰com| 中文字幕在线观看一区| 亚洲图片欧美色图| 蜜桃av一区二区在线观看| 国产一区二区三区在线观看精品| 成人毛片老司机大片| 91蜜桃网址入口| 日韩免费看的电影| 国产精品久久久久桃色tv| 亚洲综合视频在线| 韩日欧美一区二区三区| av成人动漫在线观看| 7777精品久久久大香线蕉| 久久精品综合网| 亚洲图片自拍偷拍| 国产91高潮流白浆在线麻豆| 99精品偷自拍| 在线综合+亚洲+欧美中文字幕| 国产一区二区三区av电影| 欧美亚一区二区| 精品免费日韩av| 亚洲色图丝袜美腿| 蜜桃久久久久久| 91国偷自产一区二区开放时间 | 国产视频一区二区三区在线观看| 最近日韩中文字幕| 精品无人码麻豆乱码1区2区| 在线免费观看日本欧美| 久久久久久久久蜜桃| 日韩精品一级二级 | 午夜视频一区二区| 成人av在线播放网址| 欧美大片在线观看一区| 亚洲一区欧美一区| 97久久超碰精品国产|