46:魔法方法6(描述符)

一、描述符概念

描述符就是将某种特殊类型的类的实例指派给另一个类的属性

特殊类型的类:至少实现以下三个方法中的一个

__get__(self, instance, ownder):访问属性,返回属性的值

__set__(self, instance, value):在属性分配操作中调用,不返回任何内容

__delete__(self, instance):控制删除操作,不返回任何内容

 

>>> class MyDecriptor:       #描述符类
    def __get__(self, instance, owner):
        print('getting....', self, instance, owner)
    def __set__(self, instance, value):
        print('setting....', self, instance, value)
    def __delete__(self, instance):
        print('deleting....', self, instance)

        
>>> class Test:
    x = MyDecriptor()


>>> test = Test()
>>> test.x
getting.... <__main__.MyDecriptor object at 0x03E0CD10> <__main__.Test object at 0x03E0C7F0> <class '__main__.Test'>
>>> test.x = 'X-man'
setting.... <__main__.MyDecriptor object at 0x03E0CD10> <__main__.Test object at 0x03E0C7F0> X-man
>>> 

 

>>> del MyProperty
>>> class MyProperty:
    def __init__(self, fget = None, fset = None, fdel = None):
        self.fget = fget
        self.fset = fset
        self.fdel = fdel
    def __get__(self, instance, owner):
        return self.fget(instance)
    def __set__(self, instance, value):
        self. fset(instance, value)
    def __delete__(self, instance):
        self.fdel(instance)
 

>>> class C:
    def __init__(self):
        self._x = None
    def getX(self):
        return self._x
    def setX(self, value):
        self._x = value
    def delX(self):
        del self._x
    x = MyProperty(getX, setX, delX)

 

>>> c = C()
>>> c.x = 'x-man'
>>> c.x
'x-man'
>>> c._x
'x-man'
>>> del c.x

二、练习

定义温度类,定义两个描述符类用于描述摄氏度和华氏度两个属性。

要求两个属性会自动进行转换,也就是说你可以给摄氏度这个属性赋值,然后打印的华氏度属性是自动转换后的结果

class Celsius:
    def __init__(self, value = 26.0):
        self.value = float(value)

    def __get__(self, instance, owner):
        return self.value
    def __set__(self, instance, value):
        self.value = float(value)
    
class Fashrenheit:
    def __get__(self, instance, owner):
        return instance.cel *1.8 +32
    def __set__(self, instance, value):
        instance.cel = (float(value)-32)/1.8 


class Temperature:
    cel = Celsius()
    fah = Fashrenheit()
    
>>> temp = Temperature()
>>> temp.cel
26.0
>>> temp.cel = 30
>>> temp.fah
86.0
>>> temp.fah = 100
>>> temp.cel
37.77777777777778
>>> 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值