您可以找到深刻的理由here和Guido的想法here.
总结一下,这是因为它们可能不像您想象的那样紧密相关.只是谈论帖子的len与__len__,但您可以在第一个链接中找到其他示例.
让我们从专注于__len__开始:
class Test1:
pass
class Test2:
def __bool__(self):
return False
class Test3:
def __len__(self):
return 0
t1 = Test1()
t2 = Test2()
t3 = Test3()
现在在布尔上下文中对t1,t2?和t3的评估是什么?
> bool(t1)为True.标准的python行为,任何未明确为False的行为均视为True.
> bool(t2)为False.明确地将对象设置为False会相应地起作用.
> bool(t3)为False.由于t3实现__len__是一个容器,并且长度为0,因此为空.根据定义,空容器在布尔上下文中被视为False.
__len__不一定只由len调用.
另一方面,len为您提供保证:
>它将返回一个正整数;
>它适用于任何容器,不仅限于列表;
>它将计算该容器中元素的数量.但是,这意味着什么取决于容器:比较
s = "A string with ?"
d = s.encode("utf-8")
print(len(s)) # outputs 15
print(len(d)) # outputs 18
因为s是字符的容器,而d是字节的容器.
?请注意,在python2中,__bool__是__nonzero__.