逻辑组合布尔值列表的最“pythonic”方式是啥?

Posted

技术标签:

【中文标题】逻辑组合布尔值列表的最“pythonic”方式是啥?【英文标题】:What is the most 'pythonic' way to logically combine a list of booleans?逻辑组合布尔值列表的最“pythonic”方式是什么? 【发布时间】:2011-04-10 01:20:27 【问题描述】:

我有一个布尔值列表,我想使用和/或进行逻辑组合。扩展的操作将是:

vals = [True, False, True, True, True, False]

# And-ing them together
result = True
for item in vals:
    result = result and item

# Or-ing them together
result = False
for item in vals:
    result = result or item

上面的每一个都有漂亮的单行吗?

【问题讨论】:

相关但不明显:***.com/questions/3570624/… 【参考方案1】:

all(iterable)

如果所有元素都返回True iterable 为真(或者如果 iterable 是空的)。

还有any(iterable)

如果有任何元素,则返回 True 可迭代 是真的。如果 iterable 为空,则返回 False

【讨论】:

【参考方案2】:

最好的方法是使用any()all() 函数。

vals = [True, False, True, True, True]
if any(vals):
   print "any() reckons there's something true in the list."
if all(vals):
   print "all() reckons there's no non-True values in the list."
if any(x % 4 for x in range(100)):
   print "One of the numbers between 0 and 99 is divisible by 4."

【讨论】:

我的布尔列表是由另一个列表上的列表理解生成的。现在我可以把它们都包起来了。不错! 好吧,如果是这样的话,你可以把它做成一个生成器表达式:

以上是关于逻辑组合布尔值列表的最“pythonic”方式是啥?的主要内容,如果未能解决你的问题,请参考以下文章

以块为单位迭代列表的最“pythonic”方式是啥?

从列表中弹出随机元素的最pythonic方法是啥?

在满足条件之前不断迭代列表的最 Pythonic 方式?

实现具有自动递增实例属性的类的最 Pythonic 方式是啥?

返回布尔值和消息的Pythonic方式[重复]

在 Python 列表上进行排序加 uniq 的最简洁方法是啥?