Вы не можете использовать property
в качестве декоратора для кода, который вы разместили, потому что он не предназначен для такого использования и не будет работать.
Если используется в качестве декоратора, property
преобразует функцию в геттер; если используется как функция, вы можете передать в метод получения, установки, удаления и документ.
locals()
возвращает всех местных жителей, поэтому у вас будет словарь с fget
, fset
, fdel
, doc
, Property
и __init__
- вызывая property
взорвать, потому что было передано слишком много аргументов.
Лично мне нравится стиль @x.setter
и @x.deleter
, так как я не получаю ненужных имен функций в пространстве имен классов.
Если вам приходится регулярно использовать 2.4, просто бросьте свой собственный (или украдите последнюю версию 2.6, как я;):
class property(object):
"2.6 properties for 2.5-"
def __init__(self, fget=None, fset=None, fdel=None, doc=None):
self.fget = fget
self.fset = fset
self.fdel = fdel
self.__doc__ = doc or fget.__doc__
def __call__(self, func):
self.fget = func
if not self.__doc__:
self.__doc__ = fget.__doc__
def __get__(self, obj, objtype=None):
if obj is None:
return self
if self.fget is None:
raise AttributeError("unreadable attribute")
return self.fget(obj)
def __set__(self, obj, value):
if self.fset is None:
raise AttributeError("can't set attribute")
self.fset(obj, value)
def __delete__(self, obj):
if self.fdel is None:
raise AttributeError("can't delete attribute")
self.fdel(obj)
def setter(self, func):
self.fset = func
return self
def deleter(self, func):
self.fdel = func
return self