Sergey Kishchenko a écrit :
In Python empty container equals False in 'if' statements:
Yes.
# prints "It's ok"
if not []:
print "It's ok"
Let's create a simple Foo class:
class Foo:
pass
Now I can use Foo objects in 'if' statements:
Yes.
#prints "Ouch!"
f=Foo()
if f:
print "Ouch!"
So, default __nonzero__ impl is to return True.
Yes. It's clearly documented FWIW.
I think, this
behaviour conflicts with 'Explicit is better than implicit'
Why so ? It *is* explicit that the default for an object is to have a
true value in a boolean context.
and
'Practicality beats purity'
Quite on the contrary. From a practical POV, the default truth values of
Python objects are most of the time what you practically want in a
boolean context - that is, any non-None object, non-empty sequence and
non-zero numeric objects are true. __nonzero__ is here for the *very
few* corner cases where this is not the sensible default.
statements. I think, throwing a TypeError
exception would be better. It will result in more explicit code with
fewer errors.
I can understand that you've been bitten by the rules regarding truth
values of Python objects. But if so, please remember that it's only
because *you* assumed something different from what's documented.
--
http://mail.python.org/mailman/listinfo/python-list