熬最深的夜喝最劣的酒————浅谈生成器(generator)

Posted jum-bolg

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了熬最深的夜喝最劣的酒————浅谈生成器(generator)相关的知识,希望对你有一定的参考价值。

测试(test)
def s():
print("stup1")
n = "第一步"
yield n # 类似于return 但是又不同于 赖克宝,剁一下,跳一下
print("stup2")
yield 2
print("stup3")
yield 3
print("stup4")
yield 4
# raise StopIteration # 抛出异常

f = s()
print(f.__next__())
print(f.__next__())
print(f.__next__())
print(f.__next__())
# print(f.__next__())
for x in f: # f为迭代对象,类似于迭代器 也可用for
print(x)
# f.__iter__() is g
# 生成器对象,实现了可迭代接口,也实现了迭代器接口
-----------------------------------------------------------------------------------------------------------


生成器实现找素数

# 素数: 只能被一和本身整除的数
class PrimeNumber(object):
def __init__(self, start, end):
self.start = start
self.end = end

def isprimenumber(self, k):
if k < 2:
return False
for x in range(2, k): # k取模依次 2-k 为0返回 Falae 否则为true
if k % x == 0:
print(-k)        # -表示非素数
return False
return True

def __iter__(self): # 生成器类入口
for k in range(self.start, self.end):
if self.isprimenumber(k):
yield k


for t in PrimeNumber(1, 100):
print(t)

以上是关于熬最深的夜喝最劣的酒————浅谈生成器(generator)的主要内容,如果未能解决你的问题,请参考以下文章

数学建模之理想解法(TOPSIS)

一文读懂IPFS—分布式存储的未来

浅谈Python Web的五大框架

币圈多空通杀,矿机挖矿能否成为新的避风港!

淘宝前端团队:浅谈 Node.js 和 PHP 进程管理

2018-5-23