Максимальная ошибка глубины рекурсии с getattr

У меня есть этот код;

class NumberDescriptor(object):
    def __get__(self, instance, owner):
        name = (hasattr(self, "name") and self.name)
        if not name:
            name = [attr for attr in dir(owner) if getattr(owner,attr) is self][0]
            self.name = name
        return getattr(instance, '_' + name)
    def __set__(self,instance, value):
        name = (hasattr(self, "name") and self.name)
        if not name:
            owner = type(instance)
            name = [attr for attr in dir(owner) if getattr(owner,attr) is self][0]
            self.name = name
        setattr(instance, '_' + name, int(value))

class Insan(object):
    yas = NumberDescriptor()

a = Insan()
print a.yas
a.yas = "osman"
print a.yas

Я получаю ошибку максимальной глубины рекурсии в строке name = [attr for attr in dir(owner) if getattr(owner,attr) is self][0]. Я хочу, чтобы эта строка давала мне имя переменной, используемой для текущего экземпляра дескриптора. Может ли кто-нибудь увидеть, что я делаю неправильно здесь?


person yasar    schedule 28.08.2012    source источник


Ответы (1)


Звонок getattr() звонит вашему __get__.

Один из способов обойти это — явным образом вызвать суперкласс object:

object.__getattribute__(instance, name)

Или, понятнее:

instance.__dict__[name]
person Charles Duffy    schedule 28.08.2012
comment
instance.__dict__[name] в общем случае может не работать с дескрипторами, не относящимися к данным. NumberDescriptor — это дескриптор данных, поэтому в данном случае он должен работать. - person jfs; 28.08.2012