Python 类方法调用中的陷阱:如何直接调用内部对象的 __str__ 方法?

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__ 方法?的详细内容,更多请关注硕下网其它相关文章!