python创建列表两种方法_Python创建生成器的两种方法

本文介绍了如何在Python中创建生成器,从基础的列表生成式转换为复杂的函数生成器,展示了斐波那契数列的生成器实现。重点讲解了生成器的工作原理、使用for循环迭代和处理StopIteration异常,以及如何利用生成器实现更高效的数据处理和递归算法。
摘要由CSDN通过智能技术生成

fcfb9656d4c91b7f86b2a10cc460108d.png

创建生成器方法

方法一

要创建一个生成器,有很多种方法。第一种方法很简单,只要把一个列表生成式的[ ]改成( )

创建L和G的区别仅在于最外层的[ ]和( ),L是一个列表,而G是一个生成器。我们可以直接打印出L的每一个元素,但我们怎么打印出G的每一个元素呢?如果要一个一个打印出来,可以通过next()函数获得生成器的下一个返回值:

0b70cd6062943bdceeaafe453d6f56b8.png

运行结果:

659ac2628a10459242e5df2bf8badf0c.png

48fd364e467a95f222ba6246fea7cf43.png

运行结果:

e08882183e011781c359775a6a8e26ef.png

生成器保存的是算法,每次调用next(G),就计算出G的下一个元素的值,直到计算到最后一个元素,没有更多的元素时,抛出StopIteration的异常。当然,这种不断调用next()实在是太变态了,正确的方法是使用for循环,因为生成器也是可迭代对象。所以,我们创建了一个生成器后,基本上永远不会调用next(),而是通过for循环来迭代它,并且不需要关心StopIteration异常。

相关推荐:《Python视频教程》

方法2

generator非常强大。如果推算的算法比较复杂,用类似列表生成式的for循环无法实现的时候,还可以用函数来实现。

比如,著名的斐波拉契数列(Fibonacci),除第一个和第二个数外,任意一个数都可由前两个数相加得到:

1, 1, 2, 3, 5, 8, 13, 21, 34, ...

斐波拉契数列用列表生成式写不出来,但是,用函数把它打印出来却很容易:

93d0b4a607150e0e9d3e52a5eac2e564.png

运行结果:

a43aebcbdcf54531c9749198f013e9ad.png

仔细观察,可以看出,fib函数实际上是定义了斐波拉契数列的推算规则,可以从第一个元素开始,推算出后续任意的元素,这种逻辑其实非常类似generator。

也就是说,上面的函数和generator仅一步之遥。要把fib函数变成generator,只需要把print(b)改为yield b就可以了:

1d77f597d029323d91efaee8df18d6fc.png

运行结果:

6299b9ef97d51f8ee7b2f69bdf8c85a2.png

在上面fib的例子,我们在循环过程中不断调用yield,就会不断中断。当然要给循环设置一个条件来退出循环,不然就会产生一个无限数列出来。同样的,把函数改成generator后,我们基本上从来不会用next()来获取下一个返回值,而是直接使用for循环来迭代:

a4c0bdd2a8e0d7f4a962540166e2f656.png

运行结果:

786e22794c4563335b3fad5dd179c396.png

但是用for循环调用generator时,发现拿不到generator的return语句的返回值。如果想要拿到返回值,必须捕获StopIteration错误,返回值包含在StopIteration的value中:

44294a5dc821d479e40e8b8b39c3a657.png

运行结果:

62fde2c764f17b232963f951dd9a64de.png

相关推荐:

三分钟看懂什么是Python生成器

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值