问题描述
我的一位学生发现,对于ell
(字符串列表)和estr
(字符串),如果{{1}的成员,则以下表达式为True
}包含在ell
中:
estr
有人可以解释为什么这在语法上是合法的吗?如果是这样,那么理解会产生什么?
解决方法
这是一个生成器表达式。
func_that_takes_any_iterable(i for i in iterable)
这就像一个列表推导,但是一个生成器,意味着它一次只生成一个元素:
>>> a = [i for i in range(10)]
>>> b = (i for i in range(10))
>>> print(a)
[0,1,2,3,4,5,6,7,8,9]
>>> print(b)
<generator object <genexpr> at 0x7fb9113fae40>
>>> print(list(b))
[0,9]
>>> print(list(b))
[]
单独使用生成器表达式时,出于语法原因,需要使用括号。当创建一个作为函数的参数时,该语法允许不使用多余的括号。
大多数函数并不关心它们给出的什么可迭代类型-列表,元组,字典,生成器等-生成器是完全有效的。与列表推导相比,它们在存储效率上也要高一些,因为它们不会预先生成全部内容。对于all()
和any()
来说,这特别好,因为这些方法一旦返回False
和True
就会立即短路。
从python 3.8开始,海象运算符:=
的语法限制是相似的-孤立地,它必须在其自己的括号内使用,但是在另一个表达式内,通常可以在没有括号的情况下使用。 / p>
这在语法上是合法的,因为它不是列表。任何形式(x表示数组中x的形式)都是生成器。可以将其视为懒惰列表,它仅在您询问时才会生成答案。
现在生成器也是可迭代的,因此将其包含在any()函数中是完全可以的。
willBeTrue = any(True for i in range(20))
因此,这基本上会生成20个True,并且任何函数都将查找任何true值;因此将返回True。
现在来看你的表情:
ans = any(t in estr for t in ell)
此{t in estr}返回一个布尔值。现在,生成器将len(ell)数量的布尔值作为值,并且任何人都认为是好..由于至少一个为真,所以我返回True。