Почему делает @foo.setter в Python не, работают на меня?

Так, я играю с декораторами в Python 2.6, и я испытываю некоторые затруднения, заставляя их работать. Вот мой файл класса:

class testDec:

    @property
    def x(self): 
        print 'called getter'
        return self._x

    @x.setter
    def x(self, value): 
        print 'called setter'
        self._x = value

То, что я думал, что это означало, должно рассматривать x как свойство, но вызывают эти функции на, получают и устанавливают. Так, я разжег НЕАКТИВНЫЙ и проверил его:

>>> from testDec import testDec
from testDec import testDec
>>> t = testDec()
t = testDec()
>>> t.x
t.x
called getter
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "testDec.py", line 18, in x
    return self._x
AttributeError: testDec instance has no attribute '_x'
>>> t.x = 5
t.x = 5
>>> t.x
t.x
5

Очевидно первый вызов работает как ожидалось, так как я называю метод считывания, и нет никакого значения по умолчанию, и он перестал работать. Хорошо, хороший, я понимаю. Однако вызов для присвоения t.x = 5 кажется, создает новое свойство x, и теперь метод считывания не работает!

Что я пропускаю?

153
задан smci 22 August 2012 в 01:44
поделиться

2 ответа

Вы, кажется, используете классические классы старого стиля в python 2. Для свойства для работы правильно необходимо использовать модернизированные классы вместо этого (в python 2, который Вы должны наследовать от object ). Просто объявите свой класс как MyClass(object):

class testDec(object):

    @property
    def x(self): 
        print 'called getter'
        return self._x

    @x.setter
    def x(self, value): 
        print 'called setter'
        self._x = value

Это работает:

>>> k = testDec()
>>> k.x
called getter
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/devel/class_test.py", line 6, in x
    return self._x
AttributeError: 'testDec' object has no attribute '_x'
>>> k.x = 5
called setter
>>> k.x
called getter
5
>>> 

Другая деталь, которая могла бы вызвать проблемы, - то, что для обоих методов нужно то же название свойства для работы. при определении метода set с другим именем как это, он не будет работать :

@x.setter
def x_setter(self, value):
    ...

И еще одна вещь, которую не абсолютно легко определить сначала, порядок: метод get должен быть определен сначала . При определении метода set сначала Вы добираетесь name 'x' is not defined ошибка.

300
ответ дан nosklo 23 November 2019 в 22:03
поделиться

Необходимо использовать модернизированные классы, которые Вы делаете путем получения класса из объекта:

class testDec(object):
   ....

Тогда это должно работать.

22
ответ дан MrTopf 23 November 2019 в 22:03
поделиться
Другие вопросы по тегам:

Похожие вопросы: