Python 类方法调用中的陷阱:如何直接调用内部对象的 __str__ 方法?
python 类方法使用方法
在 python 中,当你希望调用一个类的方法时,通常可以使用该类名后跟点号操作符(. ),然后是方法名。然而,在某些情况下,你可能希望直接调用类的属性,而不是方法。本文将探讨这个问题,并提供一种解决方法。
假设你编写了以下代码:
class pointer: def __init__(self, value=none): self.__interior = true self.__value = value self.__interior = false def __getattribute__(self, item): if super().__getattribute__('_pointer__interior'): return super().__getattribute__(item) if item == '__value' or item == '_pointer__value': return super().__getattribute__('_pointer__value') return getattr(super().__getattribute__('_pointer__value'), item) def __setattr__(self, item, value): if item == '_pointer__interior': super().__setattr__('_pointer__interior', value) elif super().__getattribute__('_pointer__interior'): super().__setattr__(item, value) else: if item == '__value' or item == '_pointer__value': super().__setattr__('_pointer__value', value) else: setattr(super().__getattribute__('__value'), item, value) class strpointer(pointer, str): pass
这个类具有一个 __getattribute__ 方法,它根据属性名来确定是调用当前类的属性还是内部存储的 str 对象的属性。
现在,想象一下你想调用 str 类的 __str__ 方法,而不是 pointer 的同名方法。按照常规方式,你会这样做:
ptr = strpointer('a') print(ptr.__str__)
但是,这会产生如下输出:
<method-wrapper '__str__' of str object at 0x0000000002572800>
这表明 __str__ 方法实际上并未被调用。这是因为 print 函数自动将传递给它的任何对象转换为字符串。它通过调用 type(object).__str__(object) 来执行此转换。
要解决这个问题,你需要为 pointer 类直接实现 __str__ 方法。这样,当你调用 print(ptr) 时,将调用 pointer 类的 __str__ 方法,而不是 str 类的 __str__ 方法。
修改后的代码如下:
class pointer: # ... 其他代码... def __str__(self): return super().__getattribute__('_pointer__value')
现在,当你调用 print(ptr) 时,输出将是:
a
这表明 pointer 类的 __str__ 方法已被成功调用。
以上就是Python 类方法调用中的陷阱:如何直接调用内部对象的 __str__ 方法?的详细内容,更多请关注硕下网其它相关文章!