python 迭代器和生成器

2022-08-22 23:12:14 字數 1568 閱讀 5175

首先關於迭代器和生成器,要明白以下幾點:

1.迭代是python最強大的功能之一,是訪問集合元素的一種方式。

2.迭代器是乙個可以記住遍歷的位置的物件。

3.迭代器物件從集合的第乙個元素開始訪問,直到所有的元素被訪問完結束。迭代器只能往前不會後退。

4.迭代器有兩個基本的方法:iter()next()

5.在 python 中,使用了 yield 的函式被稱為生成器(generator)。

6.跟普通函式不同的是,生成器是乙個返回迭代器的函式,只能用於迭代操作,更簡單點理解生成器就是乙個迭代器。

7.在呼叫生成器執行的過程中,每次遇到 yield 時函式會暫停並儲存當前所有的執行資訊,返回 yield 的值, 並在下一次執行 next() 方法時從當前位置繼續執行。

8.呼叫乙個生成器函式,返回的是乙個迭代器物件。

這些是在網上蒐集的關於迭代器和生成器的一些基本知識,下面是我根據這些做的練習

list=[1,2,3,4]

print(list)

it=iter(list)

for i in it:

if i == 4:

print("four")

break

print(i,end="")

import sys # 引入 sys 模組

list = [1, 2, 3, 4]

it = iter(list) # 建立迭代器物件

while true:

try:

print(next(it))

except stopiteration:

sys.exit()

'''class mynumbers:

def __iter__(self):

self.a = 1

return self

def __next__(self):

x = self.a

self.a += 1

return x

'''myclass = mynumbers()

myiter = iter(myclass)

print(next(myiter))

print(next(myiter))

print(next(myiter))

print(next(myiter))

print(next(myiter))

import sys

def fibonacci(n):

a, b, counter = 0, 1, 0

while true:

if (counter > n):

return

yield a

a, b = b, a + b

counter += 1

f = fibonacci(10)

while true:

try:

print(next(f), end=" ")

except stopiteration:

sys.exit()

Python迭代器和生成器

先說迭代器,對於string list dict tuple等這類容器物件,使用for迴圈遍歷是很方便的。在後台for語句對容器物件呼叫iter 函式,iter 是python的內建函式。iter 會返回乙個定義了next 方法的迭代器物件,它在容器中逐個訪問容器內元素,next 也是python的...

Python迭代器和生成器

迭代器是訪問集合元素的一種方法 是可以記住遍歷的位置的物件。迭代器物件從集合的第乙個元素開始訪問,直到所有的元素被訪問 他有兩個基本的方法,iter 和next 字串,列表或遠足物件都可以用於建立迭代器 list1 1,2,3,4 it1 iter list1 建立迭代器物件 print next ...

python 迭代器和生成器

迭代器是訪問集合元素的一種方式。迭代器物件從集合的第乙個元素開始訪問,直到所有的元素被訪問完結束。迭代器只能往前不會後退,不過這也沒什麼,因為人們很少在迭代途中往後退。另外,迭代器的一大優點是不要求事先準備好整個迭代過程中所有的元素。迭代器僅僅在迭代到某個元素時才計算該元素,而在這之前或之後,元素可...