加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Python列表理解在guard和result中具有相同的功能

发布时间:2020-12-16 22:53:51 所属栏目:Python 来源:网络整理
导读:我想知道是否有人有一个很好的干净Pythonic和有效的技术来实现在结果中涉及保护中相同表达的理解. 需要说明的是,请考虑以下简单示例: def f(a): print "Calling",a return a + 1print [ f(v) for v in xrange(3) if f(v) 1 ] 这将打印 Calling 0Calling 1Ca

我想知道是否有人有一个很好的干净Pythonic和有效的技术来实现在结果中涉及保护中相同表达的理解.
需要说明的是,请考虑以下简单示例:

def f(a):
    print "Calling",a
    return a + 1

print [ f(v) for v in xrange(3) if f(v) > 1 ]

这将打印

Calling 0
Calling 1
Calling 1
Calling 2
Calling 2
[2,3]

证明f对于大多数元素被调用两次.这很好,如果f有副作用,我们想要什么,但如果f是一些没有副作用的昂贵操作,重复调用是不可取的.但是对于每个元素只调用f一次的解决方案对我来说似乎笨拙/冗长:

intermediate = ( f(v) for v in xrange(3) ) 
print [ r for r in intermediate if r > 1 ]

即使它被收缩成一条线

print [ r for r in ( f(v) for v in xrange(3) ) if r > 1 ]

那么,任何人都能想出更好的东西吗?

最佳答案
您可以使用filter()函数:

filter(lambda x: x > 1,[ f(v) for v in xrange(3)])

但这与您上次建议的解决方案一样冗长.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读