迭代器,生成器

iterator: 任何实现了__iter__和 __next__方法的对象都是迭代器

 __iter__ 返回迭代器自身
 __next__返回容器中的下一个值
 如果容器中没有更多元素,则抛出Stoplteration异常2

generator:生成器其实是一种特殊的迭代器,不需要自定义__iter__ 和__next__

生成器函数(yield)
生成器表达式

例如1

自定义一个迭代器,实现斐波那契数列

class Fib(object):
	def __init__(self,max):
		self.x = 0 
		self.y = 1
		self.max = max
	
	def  __iter__(self):
		return self

	def __next__(self):
		n_next = self.y
		self.x,self.y = self.y,self.x+self.y
		if self.max >self.x:
			return n_next
		else:
			raise StopIterration('随便报一个错')

例如2

自定义一个生成器函数,实现斐波那契数列

def fid(max) :
	x = 0
	y = 1
	while y<max:
		yield y
		x,y=y,x+y

例如3

定义一个随机数迭代器,随机范围为[1,50],最大迭代次数30
import random 
def Itertion()
	for i in range(30):
		yield random.randint(1,50)
	
item = Itertion()
for  i in item :
	print(i)

迭代器和生成器有什么好处

节省空间
惰性求值
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的迭代器生成器是一种基于惰性计算的概念,它们可以有效地处理大量的数据或者无限序列。下面我将分别介绍迭代器生成器迭代器(Iterator)是一个实现了迭代协议(Iterator Protocol)的对象。通过调用内置函数 `iter()` 可以将可迭代对象转换为迭代器迭代器对象可以使用内置函数 `next()` 来逐个访问数据元素,直到没有更多的元素可供访问时,会引发 `StopIteration` 异常。例如,可以使用迭代器来遍历列表、元组、集合等容器类型的数据。 生成器(Generator)则是一种特殊的迭代器。它不需要显式地实现迭代协议,而是通过函数中的 `yield` 关键字来实现惰性计算。生成器函数在每次调用时返回一个值,并在下一次调用时从上一次离开的位置继续执行。这样可以节省大量的内存空间,并且提高程序的效率。生成器函数定义时使用 `def` 关键字,并包含至少一个 `yield` 关键字。 下面是一个简单的示例代码,演示了如何使用迭代器生成器: ```python # 使用迭代器遍历列表 my_list = [1, 2, 3, 4, 5] my_iter = iter(my_list) while True: try: item = next(my_iter) print(item) except StopIteration: break # 使用生成器生成斐波那契数列 def fibonacci(): a, b = 0, 1 while True: yield a a, b = b, a + b fib = fibonacci() for i in range(10): print(next(fib)) ``` 希望以上解释能够帮助你理解迭代器生成器的概念。如果有任何进一步的问题,请随时提问!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值