首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >itertools.ifilter Vs.过滤器Vs。列表理解

itertools.ifilter Vs.过滤器Vs。列表理解
EN

Stack Overflow用户
提问于 2012-01-25 05:19:34
回答 3查看 21.1K关注 0票数 29

我正在尝试更熟悉itertools模块,并找到了一个名为ifilter的函数。

据我所知,它根据给定的函数过滤和迭代,并在包含可迭代元素的列表上返回迭代器,函数的计算结果为True

问题1:到目前为止我的理解是正确的吗?

问题2:除了返回和迭代器之外,它与内置的filter函数有什么不同?

问题3哪个更快?

据我所知,事实并非如此。我是不是遗漏了什么?(我运行了以下测试)

代码语言:javascript
复制
>>> itertools.ifilter(lambda x: x%2, range(5))
<itertools.ifilter object at 0x7fb1a101b210>
>>> for i in itertools.ifilter(lambda x: x%2, range(5)): print i
... 
1
3
>>> filter(lambda x: x%2, range(5))
[1, 3]
>>> function = lambda x: x%2
>>> [item for item in range(5) if function(item)]
[1,3]
EN

回答 3

Stack Overflow用户

发布于 2012-01-25 07:31:51

您的理解是正确的:唯一的区别是ifilter返回迭代器,而使用filter类似于调用:

代码语言:javascript
复制
list(ifilter(...))

您可能还会对PEP 289对filter和ifilter的看法感兴趣:

列表理解极大地减少了对filter()map()的需求。同样,生成器表达式有望最大限度地减少对itertools.ifilter()itertools.imap()的需求。..。

还要注意,在Python-3中,ifilter变成了filter (因此从itertools中删除)。

票数 21
EN

Stack Overflow用户

发布于 2012-01-25 05:22:15

ifilter返回一个生成器,而不是一个列表。

生成器在需要时动态创建它们的项,而不是首先分配整个列表。这是ifilterfilter之间唯一的区别

票数 4
EN

Stack Overflow用户

发布于 2012-01-25 05:27:45

在这里,您可以看到差异:

filter(function, iterable)从函数返回true的那些元素构造一个列表迭代器。

itertools.ifilter(predicate, iterable)创建一个 ,用于过滤iterable中的元素,只返回谓词为True的元素。

这意味着要获得'ifiltered‘项,你应该使用返回的迭代器进行迭代,但是'filter’返回列表中的所有元素,而不需要迭代。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8994319

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档