发布于2019-08-07 10:59 阅读(747) 评论(0) 点赞(2) 收藏(0)
可以理解为一种数据类型,这种数据类型自动实现了迭代器协议(其他数据类型需要调用__iter__方法),所以生成器就是一种迭代器。
使用yield代替return返回结果,yield语句一次返回一个结果,返回一个结果后,挂起函数的状态,下次从yield的位置继续执行。
def fib(max): n, a, b = 0, 0, 1 while n < max: yield b a, b = b, a + b n = n + 1 return 'done' f = fib(10) print(next(f)) print(next(f)) print(next(f)) print(next(f))
# 函数是顺序执行,遇到return语句或者最后一行函数语句就返回。而变成generator的函数,在每次调用next()的时候执行,遇到yield语句返回,再次执行时从上次返回的yield语句处继续执行。 def odd(): print('step 1') yield 1 print('step 2') yield(3) print('step 3') yield(5) >>> o = odd() >>> next(o) step 1 1 >>> next(o) step 2 3 >>> next(o) step 3 5 >>> next(o) Traceback (most recent call last): File "<stdin>", line 1, in <module> StopIteration
def test(): print('开始啦') first = yield 1 print('第一次', first) yield 2 print('第二次') yield 3 print('第三次') # yield 1相当于return,控制的是函数的返回值 # yield可以接收send传过来的值 t = test() res = t.__next__() print(res) t.send('hello')
# 三元表达式 name = 'alex' res = 'SB' if name == 'alex' else '123' print(res) SB # 列表解析 l1 = ['鸡蛋%s' % i for i in range(1, 10)] l2 = ['鸡蛋%s' % i for i in range(1, 10) if i > 5] # l3 = ['鸡蛋%s' % i for i in range(1, 10) if i > 5 else i] # 没有四元表达式 print(l1) print(l2) ['鸡蛋1', '鸡蛋2', '鸡蛋3', '鸡蛋4', '鸡蛋5', '鸡蛋6', '鸡蛋7', '鸡蛋8', '鸡蛋9'] ['鸡蛋6', '鸡蛋7', '鸡蛋8', '鸡蛋9'] # 生成器表达式 g = ('鸡蛋%s' % i for i in range(1, 10) if i > 5) print(next(g)) print(next(g)) print(next(g)) print(next(g)) 鸡蛋6 鸡蛋7 鸡蛋8 鸡蛋9
延迟计算,一次产生一个数据,也就是说不会一次产生全部结果,对于大量数据的处理非常有用。
sum([x for x in range(1000000000)]) # 一次计算全部结果,占用大量内存 sum(x for x in range(1000000000)) # 一次计算一个结果,几乎不占内存
有效提高代码可读性
作者:大将军
链接:https://www.pythonheidong.com/blog/article/10100/4e81529a026eb1944c52/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!