简短的回答: 是的!
根据Python文档(我突出了相关部分):
object.__str__(self)由 str(object)
和内置函数format()和print()调用以计算对象的“非正式”或可很好打印的字符串表示形式。返回值必须是一个字符串对象。此方法的不同之处在于,
object.__repr__()不期望__str__()返回有效的Python表达式:可以使用更方便或更简洁的表示形式。内置类型object invokes定义的默认实现
object.__repr__()。
所以
your_instance.__str__通常在您做的时候被称为
str(your_instance)。
更长的答案:对于“特殊方法”(具有两个前导下划线和两个尾随下划线的方法),将出现异常,因为它们是在类而不是实例上查找的。所以,
str(a)实际上是
type(a).__str__(a)和不是
a.__str__()。但是在大多数情况下,它们是相同的,因为很少会覆盖实例上类的方法。尤其不是特殊的方法。
另请参见有关“特殊方法查找”的文档:
对于自定义类,只有在对 对象的类型* (而不是在 对象的实例字典中)进行 定义的情况下,才能保证对特殊方法的 隐式调用
可以正常工作。 ***
因此,就像@ zzh1996在注释中指出的那样,即使实例具有自定义的callable
__str__属性,以下代码也将使用在类上定义的方法:
>>> class A(object):... def __str__(self):... return 'a'>>> instance = A()>>> instance.__str__ = lambda: 'b'>>> str(instance)'a'>>> instance.__str__()'b'
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)