python生成器简单了解
1.什么是生成器
通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。所以生成器就出现了,他弥补了直接生成大列表的不足,改成为定义某种计算过程,然后在需要的时候进行计算后得出想要的结果,从而节省了大量的内存空间。这就是生成器:generator
2.生成器的写法
第一种生成器的写法很简单,就是将列表生成式的[]改成()就得到了一个生成器,如下图。
列表生成式
生成器
这里可以看到在打印ll的时候并没有输出值,那我们应该怎么让他输出我们想要的东西呢?这时我们就要通过next()来输出了。
这里我们看到通过next()就将我们想要的值一一输出了。这里注意是每调用一次next就会输出一个值,然后再调用一次next会输出下个一值,一直到最后一个值输出。如果在全部被输出完成后再调用next则会报错。
第二种方法:yield
生成器非常强大,绝对不会只能完成上面的简单的工作,下面我们将会用生成器完成一个复杂的操作!斐波那契数列!(不知道此数列的请自行百度 除第一个和第二个数外,任意一个数都可由前两个数相加得到:1, 1, 2, 3, 5, 8, 13, 21, 34, ...)
这里的next(f)还可以用__next__()代替,用法如下