本篇文章小编给大家分享一下Python魔法方法之描述符类代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
描述符类要求:
描述符就是将某种特殊类型的类的实例指派给另一个类的属性
至少要实现以下的一个方法:
•__get__(self, instance, owner) –用于访问属性,它返回属性的值 •__set__(self, instance, value) –将在属性分配操作中调用,不返回任何内容 •__delete__(self, instance) –控制删除操作,不返回任何内容
eg:
>>> 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() #取Mydecriptor类的实例指派给Test类的属性x
测试:
eg:
>>> 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 = "HELLOW" >>> c.x 'HELLOW' >>> c._x 'HELLOW' >>> del c.x >>> c._x
eg:
摄氏度转华氏度:华氏度=摄氏度*1.8+32
要求:
•先定义一个温度类,然后定义两个描述符类用于描述摄氏度和华氏度两个属性。
•要求两个属性会自动进行转换,也就是说你可以给摄氏度这个属性赋值,然后打印的华氏度属性是自动转换后的结果。
ss Celsius: #摄氏度描述符类 def __init__(self,value = 26.0):#self为描述符类自身(此为摄氏度描述符类)的实例(此为cel) self.value = float(value) def __get__(self,instance,owner):#instance是这个描述符的拥有者所在的类的实例(此为temp) return self.value def __set__(self,instance,value):#owner是这个描述符的拥有者所在的类本身(此为温度类) self.value = float(value) class Fahrenheit: #华氏度描述符类 def __get__(self,instance,owner): return instance.cel * 1.8 +32 #摄氏度转华氏度 def __set__(self,instance,value): instance.cel = ((float)(value)- 32)/ 1.8 ## instance.cel 则会执行Temperature.cel,接着执行Celsius类中的__set__方法 class Temperature: #温度类 cel = Celsius() #设置摄氏度属性(描述符类的实例指派给了温度类的属性) fah = Fahrenheit()# temp.fah ,当属性fah被赋值的时候,则会执行Fahrenheit描述符类的__set__方法 >>> temp = Temperature() >>> temp.cel 26.0 >>> temp.fah 78.80000000000001 >>> temp.fah = 78.8 >>> temp.cel 25.999999999999996