我正在编写一个 Python 类,并使用 @property
装饰器为该类创建属性。
我在文档中没有找到太多关于这个装饰器的信息,但是从我可以从 Stack Overflow 和我的 Python linter 中收集到的信息中:总的来说,使用属性装饰器创建的属性可以采用以下形式 < em>定义、getter、setter、deleter,如下图:
@property
def name(self):
return self.__name
@name.getter
def name(self):
return self.__name
@name.setter
def name(self, value):
self.__name=value
@name.deleter
def name(self):
del self.__name
我不完全确定第一个 block 的用途。里面的代码和getter
函数一模一样。
第一个 block 是干什么用的;它与 getter
block 有什么不同,如果不是,我可以删除其中任何一个吗?
最佳答案
您的代码工作方式相同,因为 @name.getter
的代码与 @property
的代码相同。
@property
是必需的,因为它定义了属性。
如果你尝试:
class MyClass:
@name.getter
def name(self):
return self.__name
您将收到错误消息:
Traceback (most recent call last):
File "/path/to/my/code/prop.py", line 1, in <module>
class MyClass:
File "/path/to/my/code/prop.py", line 3, in MyClass
@name.getter
NameError: name 'name' is not defined
因此,在创建属性时,您总是从以下内容开始:
@property
def name(self):
return self.__name
这将创建属性 name
以及该属性的 getter
,您可以在此处看到:
class MyClass:
@property
def name(self):
return self.__name
print(MyClass.name) # Note: we didn't create any objects
print(MyClass.name.getter)
输出将是:
<property object at 0x10beee050>
<built-in method getter of property object at 0x10beee050>
如果添加getter
,这会覆盖原来的getter
。
在你的情况下,两个 setter/getter 是相同的,所以没有变化。但是尝试更改代码,使新的 getter 有所不同:
class MyClass:
@property
def name(self): # property and original getter
print('This one will never get called')
return self.__name
@name.getter
def name(self): # redefined getter
return 'hello '+self.__name
现在这个类有了一个新的getter,如果你创建一个对象obj
然后使用obj.name
,新的getter
会被调用,而不是原来的。
关于Python @property 与 @property.getter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66356016/