Python hace cosas especiales con las comparaciones encadenados.
La siguiente se evalúan de forma diferente:
x > y > z # in this case, if x > y evaluates to true, then
# the value of y is being used to compare, again,
# to z
(x > y) > z # the parenth form, on the other hand, will first
# evaluate x > y. And, compare the evaluated result
# with z, which can be "True > z" or "False > z"
En ambos casos, sin embargo, si la primera comparación es False
, el resto de la declaración no se observó.
para su caso particular,
1 in [] in 'a' # this is false because 1 is not in []
(1 in []) in a # this gives an error because we are
# essentially doing this: False in 'a'
1 in ([] in 'a') # this fails because you cannot do
# [] in 'a'
también para demostrar la primera regla anterior, se trata de declaraciones que se evalúan como True.
1 in [1,2] in [4,[1,2]] # But "1 in [4,[1,2]]" is False
2 <4> 1 # and note "2 < 1" is also not true
Precedencia de operadores Python: http://docs.python.org/reference/expressions.html#summary
Probablemente esté siguiendo el comportamiento descrito aquí: http://docs.python.org/reference/expressions.html#not-in, el que le permite escribir 'if a millimoose
@millimoose: Sí, nunca pensé en 'in' como un operador de" comparación ", supongo. : \ – Mehrdad
Hola [¿Qué tipo de analizador se utiliza en el intérprete de Python?] (Http://stackoverflow.com/questions/15532616/what-type-of-parser-is-used-in-python-interpreter) –