生成器函数

def vowel©:
return c.lower() in ‘aeiou’
print(list(filter(vowel,‘Aardvark’)))#[‘A’, ‘a’, ‘a’]
print(list(filterfalse(vowel,‘Aardvark’)))#[‘r’, ‘d’, ‘v’, ‘r’, ‘k’]
#filter和filterfalse的结果互斥对立
print(list(dropwhile(vowel,‘Aardvark’)))#[‘r’, ‘d’, ‘v’, ‘a’, ‘r’, ‘k’],取出第一个返回false的元素以及后面的所有元素
print(list(takewhile(vowel,‘Aardvark’)))#[‘A’, ‘a’],取出第一个返回false的元素之前的所有元素,不包括这个元素
#dropwhile和takewhile的结果互斥对立
print(list(compress(‘Aardvark’,[1,0,1,1,0,1])))#[‘A’, ‘r’, ‘d’, ‘a’] 只取出对应位置为true的元素
print(list(islice(‘Aardvark’,4)))#[‘A’, ‘a’, ‘r’, ‘d’]
print(list(islice(‘Aardvark’,4,7)))#[‘v’, ‘a’, ‘r’]
print(list(islice(‘Aardvark’,1,7,2)))#[‘a’, ‘d’, ‘a’]

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,生成器函数是一种特殊类型的函数,它使用 yield 关键字来返回一个迭代器。生成器函数可以用于按需生成值,而不是一次性生成所有值。 生成器函数的定义与普通函数类似,但使用 yield 语句而不是 return 语句来返回值。当调用生成器函数时,它会返回一个生成器对象,而不会立即执行函数体。每次迭代生成器对象时,函数会从上次暂停的位置继续执行,并返回 yield 语句后的值,直到没有更多的 yield 语句为止。 下面是一个简单的生成器函数示例,用于生成斐波那契数列: ```python def fibonacci(): a, b = 0, 1 while True: yield a a, b = b, a + b fib = fibonacci() for i in range(10): print(next(fib)) ``` 在上面的例子中,定义了一个名为 fibonacci 的生成器函数。它使用 while 循环和 yield 语句来生成斐波那契数列中的每个值。每次调用 next() 函数时,生成器会从上次暂停的位置继续执行,并返回 yield 语句后的值。 通过调用 fibonacci() 函数,我们得到了一个生成器对象 fib。然后使用 for 循环和 next() 函数迭代该生成器对象,打印出斐波那契数列的前 10 个数。 输出结果为: ``` 0 1 1 2 3 5 8 13 21 34 ``` 生成器函数的优点是它们可以按需生成值,而不需要一次性生成所有值,这在处理大量数据或无限序列时非常有用。由于生成器函数的特殊性质,它们具有较低的内存消耗,并且可以以一种更高效的方式实现迭代逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值