Python进阶之“属性(property)”详解
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Python进阶之“属性(property)”详解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含7504字,纯文字阅读大概需要11分钟。
内容图文
Python中有一个被称为属性函数(property)的小概念,它可以做一些有用的事情。在这篇文章中,我们将看到如何能做以下几点:
- 将类方法转换为只读属性
- 重新实现一个属性的setter和getter方法
在本文中,您将学习如何以几种不同的方式来使用内置的属性函数。希望读到文章的末尾时,你能看到它是多么有用。
开始
使用属性函数的最简单的方法之一是将它作为一个方法的装饰器来使用。这可以让你将一个类方法转变成一个类属性。当我需要做某些值的合并时,我发现这很有用。其他想要获取它作为方法使用的人,发现在写转换函数时它很有用。让我们来看一个简单的例子:
class Person(object):
""""""
def __init__(self, first_name, last_name):
"""Constructor"""
self.first_name = first_name
self.last_name = last_name
@property
def full_name(self):
"""
Return the full name
"""
return "%s %s" % (self.first_name, self.last_name)
xxxxxxxxxx
class
Person(object):
""""""
def__init__(self, first_name, last_name):
"""Constructor"""
self.first_name = first_name
self.last_name = last_name
@property
deffull_name(self):
"""
Return the full name
"""
return"%s %s"% (self.first_name, self.last_name)
>>> person = Person("Mike", "Driscoll")
>>> person.full_name
‘Mike Driscoll‘
>>> person.first_name
‘Mike‘
>>> person.full_name = "Jackalope"
Traceback (most recent call last):
File "<string>", line 1, in <fragment>
AttributeError: can‘t set attribute
xxxxxxxxxx
>>>
person = Person("Mike", "Driscoll")
>>>
person.full_name
‘Mike Driscoll‘
>>>
person.first_name
‘Mike‘
>>>
person.full_name = "Jackalope"
Traceback (mostrecentcalllast):
File"<string>", line1, in<fragment>
AttributeError: can‘t set attribute
>>> person.first_name = "Dan"
>>> person.full_name
‘Dan Driscoll‘
xxxxxxxxxx
>>>
person.first_name = "Dan"
>>>
person.full_name
‘Dan Driscoll‘
这是一种限制,因此让我们来看看另一个例子,其中我们可以创建一个允许设置的属性。
使用Python property取代setter和getter方法
让我们假设我们有一些遗留代码,它们是由一些对Python理解得不够好的人写的。如果你像我一样,你之前已经看到过这类的代码:
from decimal import Decimal
########################################################################
class Fees(object):
""""""
#----------------------------------------------------------------------
def __init__(self):
"""Constructor"""
self._fee = None
#----------------------------------------------------------------------
def get_fee(self):
"""
Return the current fee
"""
return self._fee
#----------------------------------------------------------------------
def set_fee(self, value):
"""
Set the fee
"""
if isinstance(value, str):
self._fee = Decimal(value)
elif isinstance(value, Decimal):
self._fee = value
xxxxxxxxxx
from
decimal
import
Decimal
########################################################################
class
Fees(object):
""""""
#----------------------------------------------------------------------
def__init__(self):
"""Constructor"""
self._fee = None
#----------------------------------------------------------------------
defget_fee(self):
"""
Return the current fee
"""
returnself._fee
#----------------------------------------------------------------------
defset_fee(self, value):
"""
Set the fee
"""
ifisinstance(value, str):
self._fee = Decimal(value)
elifisinstance(value, Decimal):
self._fee = value
要使用这个类,我们必须要使用定义的getter和setter方法:
>>> f = Fees()
>>> f.set_fee("1")
>>> f.get_fee()
Decimal(‘1‘)
xxxxxxxxxx
>>>
f = Fees()
>>>
f.set_fee("1")
>>>
f.get_fee()
Decimal(‘1‘)
如果你想添加可以使用正常点符号访问的属性,而不破坏所有依赖于这段代码的应用程序,你可以通过添加一个属性函数非常简单地改变它:
from decimal import Decimal
########################################################################
class Fees(object):
""""""
#----------------------------------------------------------------------
def __init__(self):
"""Constructor"""
self._fee = None
#----------------------------------------------------------------------
def get_fee(self):
"""
Return the current fee
"""
return self._fee
#----------------------------------------------------------------------
def set_fee(self, value):
"""
Set the fee
"""
if isinstance(value, str):
self._fee = Decimal(value)
elif isinstance(value, Decimal):
self._fee = value
fee = property(get_fee, set_fee)
xxxxxxxxxx
from
decimal
import
Decimal
########################################################################
class
Fees(object):
""""""
#----------------------------------------------------------------------
def__init__(self):
"""Constructor"""
self._fee = None
#----------------------------------------------------------------------
defget_fee(self):
"""
Return the current fee
"""
returnself._fee
#----------------------------------------------------------------------
defset_fee(self, value):
"""
Set the fee
"""
ifisinstance(value, str):
self._fee = Decimal(value)
elifisinstance(value, Decimal):
self._fee = value
fee = property(get_fee, set_fee)
我们在这段代码的末尾添加了一行。现在我们可以这样做:
>>> f = Fees()
>>> f.set_fee("1")
>>> f.fee
Decimal(‘1‘)
>>> f.fee = "2"
>>> f.get_fee()
Decimal(‘2‘)
xxxxxxxxxx
>>>
f = Fees()
>>>
f.set_fee("1")
>>>
f.fee
Decimal(‘1‘)
>>>
f.fee = "2"
>>>
f.get_fee()
Decimal(‘2‘)
正如你所看到的,当我们以这种方式使用属性函数时,它允许fee属性设置并获取值本身而不破坏原有代码。让我们使用属性装饰器来重写这段代码,看看我们是否能得到一个允许设置的属性值。
from decimal import Decimal
########################################################################
class Fees(object):
""""""
#----------------------------------------------------------------------
def __init__(self):
"""Constructor"""
self._fee = None
#----------------------------------------------------------------------
@property
def fee(self):
"""
The fee property - the getter
"""
return self._fee
#----------------------------------------------------------------------
@fee.setter
def fee(self, value):
"""
The setter of the fee property
"""
if isinstance(value, str):
self._fee = Decimal(value)
elif isinstance(value, Decimal):
self._fee = value
#----------------------------------------------------------------------
if __name__ == "__main__":
f = Fees()
xxxxxxxxxx
from
decimal
import
Decimal
########################################################################
class
Fees(object):
""""""
#----------------------------------------------------------------------
def__init__(self):
"""Constructor"""
self._fee = None
#----------------------------------------------------------------------
@property
deffee(self):
"""
The fee property - the getter
"""
returnself._fee
#----------------------------------------------------------------------
@fee.setter
deffee(self, value):
"""
The setter of the fee property
"""
ifisinstance(value, str):
self._fee = Decimal(value)
elifisinstance(value, Decimal):
self._fee = value
#----------------------------------------------------------------------
if
__name__ == "__main__":
f = Fees()
上面的代码演示了如何为fee属性创建一个setter方法。你可以用一个名为@fee.setter的装饰器装饰第二个方法名也为fee的方法来实现这个。当你如下所做时,setter被调用:
>>> f = Fees()
>>> f.fee = "1"
xxxxxxxxxx
>>>
f = Fees()
>>>
f.fee = "1"
如果你看属性函数的说明,它有fget, fset, fdel和doc几个参数。如果你想对属性使用del命令,你可以使用@fee.deleter创建另一个装饰器来装饰相同名字的函数从而实现删除的同样效果。
结束语
现在你知道如何在你的类中使用Python的属性函数。希望你能找到更有用的方式,在你的代码中使用它们。
原文:https://www.cnblogs.com/churao/p/8494284.html
内容总结
以上是互联网集市为您收集整理的Python进阶之“属性(property)”详解全部内容,希望文章能够帮你解决Python进阶之“属性(property)”详解所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。