Python中为什么”1 in [1,0] == True”的结果是False?

问题:

当我查看this question的答案时,我发现我不明白我自己的答案。
我真的不明白这是如何被解析的。为什么第二个例子返回False?

>>> 1 in [1,0]             # This is expected
True
>>> 1 in [1,0] == True     # This is strange
False
>>> (1 in [1,0]) == True   # This is what I wanted it to be
True
>>> 1 in ([1,0] == True)   # But it's not just a precedence issue!
                           # It did not raise an exception on the second example.

Traceback (most recent call last):
  File "<pyshell#4>", line 1, in <module>
    1 in ([1,0] == True)
TypeError: argument of type 'bool' is not iterable

感谢任何帮助。我想我一定很想念一些非常明显的东西。
我认为这与链接的重复是微妙的不同:
Why does the expression 0 < 0 == 0 return False in Python?
这两个问题都与人类对表达的理解有关。评价表达方式似乎有两种方式(在我看来)。当然不是正确的,但在我的例子中,最后的解释是不可能的。
看看0 < 0 == 0,你可以想象每一半被评估,并作为一个表达方式有意义:

>>> (0 < 0) == 0
True
>>> 0 < (0 == 0)
True

所以链接回答了为什么评估False

>>> 0 < 0 == 0
False

但是,我的例子1 in ([1,0] == True)不是一个表达方式,所以,而不是有两个(肯定是错误的)可能的解释,只有一个似乎是可能的:

>>> (1 in [1,0]) == True

回答:

Python实际上应用了比较运算符链接。表达式被翻译成

(1 in [1, 0]) and ([1, 0] == True)

这显然是False
这也发生在表达式上

a < b < c

翻译成

(a < b) and (b < c)

(不评估b两次)。
有关详细信息,请参阅Python language documentation

Code问答: http://codewenda.com/topics/python/
Stackoverflow: Why does (1 in [1,0] == True) evaluate to False?

发表评论

电子邮件地址不会被公开。 必填项已用*标注

97 − = 95