接触Python以来,一直用的自带的IDLE进行调试,着实不太方便。老也看到别的公众号分享的 anaconda,并不知道是什么,今天依葫芦画瓢安装了一下,并选取了spyder编辑器进行了今天的一个重要问题的研究--生成器(generator)。
生成器引申于列表生成式:
通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。在Python中,这种一边循环一边计算的机制,称为生成器:generator*(摘)
方法1:L是一个列表生成式,[]改为():g即为一个generator
绝大多数情况下,使用for循环调用,因为generator也是可迭代对象。
方法2:如果一个函数定义中把print变为yield 关键字,那么这个函数就不再是一个普通函数,而是一个generator
方法1其实很简单,我整晚都在琢磨方法2,理解示例为杨辉三角~核心在于生成下一个元素的算法,这种逻辑思维有点等同于高中时期的数列,根据规律找出表达式或由已知条件推算表达式!!!此例中的关键就在于代码中的 “for 循环”
spyder画面:
调试结果:
头晕,睡觉!
领取专属 10元无门槛券
私享最新 技术干货