|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- '''
- 目的:利用生成器实现可迭代对象,以判断输出素数为例
- '''
- class Primenumbers():
- def __init__(self,start,end):
- self.start = start
- self.end = end
- def isPrimenum(self,k):
- if k < 2:
- return False
- for x in range(2,k):
- if k % x == 0:
- return False
- return True
- def __iter__(self):
- for i in range(self.start,self.end+1):
- if self.isPrimenum(i):
- yield i
- for x in Primenumbers(1,100):
- print(x)
- '''
- 提问与思考:
- 1、一个带有 yield 的函数就是一个 generator(生成器),它和普通函数不同,
- 生成一个 generator 看起来像函数调用,但不会执行任何函数代码,
- 直到对其调用 next()(在 for 循环中会自动调用 next())才开始执行。
- 虽然执行流程仍按函数的流程执行,但每执行到一个 yield 语句就会中断,
- 并返回一个迭代值,下次执行时从 yield 的下一个语句继续执行。
- 看起来就好像一个函数在正常执行的过程中被 yield 中断了数次,
- 每次中断都会通过 yield 返回当前的迭代值。
- '''
复制代码 |
|