1.property用法app
# class Goods: # def __init__(self): # # 原價 # self.original_price = 100 # # 折扣 # self.discount = 0.8 # # @property # def price(self): # # 實際價格 = 原價 * 折扣 # new_price = self.original_price * self.discount # return new_price # # @price.setter # def price(self, value): # self.original_price = value # # @price.deleter # def price(self): # del self.original_price class Goods: def __init__(self): self.original_price = 100 self.discount = 0.8 @property def price(self): new_price = self.original_price * self.discount return new_price @price.setter def price(self,value): self.original_price = value @price.deleter def price(self): del self.original_price obj = Goods() print(obj.price) obj.price = 200 print(obj.price) del obj.price print(obj.price) # obj = Goods() # print(obj.price) # 獲取商品價格 # obj.price = 200 # 修改商品原價 # print(obj.price) # del obj.price # 刪除商品原價 # print(obj.price)
2.property補充函數
# class Foo: # @property # def AAA(self): # print('get的時候運行我啊') # # @AAA.setter # def AAA(self,val): # print('set的時候運行我啊',val) # @AAA.deleter # def AAA(self): # print('del的時候運行我啊') # #只有在屬性AAA定義property後才能定義AAA.setter,AAA.deleter # f1=Foo() # f1.AAA # f1.AAA='aaa' # del f1.AAA # class Foo: # # def get_AAA(self): # print('get的時候運行我啊') # def set_AAA(self,val): # print('set的時候運行我啊',val) # def del_AAA(self): # print('del的時候運行我啊') # # AAA=property(get_AAA,set_AAA,del_AAA) # #只有在屬性AAA定義property後才能定義AAA.setter,AAA.deleter # f1=Foo() # f1.AAA # f1.AAA='aaa' # del f1.AAA
3.上下文管理協議spa
# class Foo: # def __init__(self,name): # self.name=name # # def __enter__(self): # print('執行enter') # return self # # def __exit__(self, exc_type, exc_val, exc_tb): # print('執行exit') # print(exc_type) # print(exc_val) # print(exc_tb) # return True # with Foo('a.txt') as f: # print(f) # print(asdfsaasdfasdfasdfasdfasfasdfasdfasdfasdfasfdasfd) #觸發__exit__ # print(f.name) # print('-----------------') # print('-----------------') # print('-----------------') # print('-----------------') # print('-----------------') # print('-----------------') # print('-----------------') # print('000000000000000000000000000000000000000000000')
with obj as f:
'代碼塊'
1.with obj ----》觸發obj.__enter__(),拿到返回值
2.as f----->f=返回值、
3.with obj as f 等同於 f=obj.__enter__()
4.執行代碼塊
一:沒有異常的狀況下,整個代碼塊運行完畢後去觸發__exit__,它的三個參數都爲None
二:有異常的狀況下,從異常出現的位置直接觸發__exit__
a:若是__exit__的返回值爲True,表明吞掉了異常
b:若是__exit__的返回值不爲True,表明吐出了異常
c:__exit__的的運行完畢就表明了整個with語句的執行完畢
#自省
hasattr(obj,'屬性') #obj.屬性 是否存在
getattr(obj,'屬性') #獲取obj.屬性 不存在則報錯
getattr(obj,'屬性','默認值') #獲取obj.屬性 不存在不會報錯,返回那個默認值
setattr(obj,'屬性','屬性的值') #obj.屬性=屬性的值
delattr(obj,'屬性') #del obj.屬性
#__getattr__,__setattr__,__delattr__
obj點的方式去操做屬性時觸發的方法
__getattr__:obj.屬性 不存在時觸發
__setattr__:obj.屬性=屬性的值 時觸發
__delattr__:del obj.屬性 時觸發
#__getitem__,__setitem_,__delitem__
obj[‘屬性’]的方式去操做屬性時觸發的方法
__getitem__:obj['屬性'] 時觸發
__setitem__:obj['屬性']=屬性的值 時觸發
__delitem__:del obj['屬性'] 時觸發
#__get__,__set__,__delete__
描述就是一個新式類,這個類至少要實現上述三個方法的一個
class 描述符:
def __get__():
pass
def __set__():
pass
def __delete__():
pass
class 類:
name=描述符()
obj=類()
obj.name #get
obj.name='egon' #set
del obj.name #delete
#__del__:析構方法
垃圾回收時觸發
4.元類介紹
# class Foo: # pass # # f1=Foo() #f1是經過Foo類實例化的對象 # # print(type(f1)) # print(type(Foo)) # # class Bar: # pass # # print(type(Bar)) # class Foo: # def __init__(self): # pass # print(Foo) # print(Foo.__dict__) # # def __init__(self,name,age): # self.name=name # self.age=age # def test(self): # print('=====>') # FFo=type('FFo',(object,),{'x':1,'__init__':__init__,'test':test}) # print(FFo) # print(FFo.__dict__) # # f1=FFo('alex',18) # print(f1.name) # f1.test()
5.利用描述符自定製propertycode
# class Lazyproperty: # def __init__(self,func): # # print('==========>',func) # self.func=func # def __get__(self, instance, owner): # print('get') # # print(instance) # # print(owner) # if instance is None: # return self # res=self.func(instance) # setattr(instance,self.func.__name__,res) # return res # def __set__(self, instance, value): # pass class Lazypropery: def __init__(self,func): self.func = func def __get__(self, instance, owner): print('get') if instance is None: return self res = self.func(instance) setattr(instance,self.func.__name__,res) return res def __set__(self, instance, value): pass class Room: def __init__(self,name,width,length): self.name = name self.width = width self.length = length @Lazypropery def area(self): return self.width*self.length @property def areal(self): return self.width*self.length print(Room.__dict__) r1 = Room('廁所',1,1) print(r1.__dict__) # class Room: # def __init__(self,name,width,length): # self.name=name # self.width=width # self.length=length # # @property #area=property(area) # @Lazyproperty #area=Lazypropery(area) # def area(self): # return self.width * self.length # @property #test=property(test) # def area1(self): # return self.width * self.length # # print(Room.__dict__) # r1=Room('廁所',1,1) # print(r1.__dict__) print(r1.area) print(Room.__dict__) #實例調用 # print(r1.area) # print(Room.__dict__) #類調用 # print(Room.area) print(Room.area) print(r1.test) print(Room.test) # print(r1.test) # print(Room.test) # print(r1.area1) # print(r1.area1) # print(r1.area1) # print(r1.area1) print(r1.areal) print(r1.areal) print(r1.areal) print(r1.areal) print(r1.areal) print(r1.areal) # print(r1.area) # print(r1.__dict__) # # print(r1.area) # print(r1.area) # print(r1.area) # print(r1.area) # print(r1.area) # print(r1.area) # print(r1.area) # print(r1.area)
6.類的裝飾器對象
# def deco(func): # print('==========') # return func # # # @deco #test=deco(test) # # def test(): # # print('test函數運行') # # test() # # @deco #Foo=deco(Foo) # class Foo: # pass # def deco(obj): # print('==========',obj) # obj.x=1 # obj.y=2 # obj.z=3 # return obj # @deco #Foo=deco(Foo) # class Foo: # pass # # print(Foo.__dict__) #一切皆對象 # # @deco #test=deco(test) # def test(): # print('test函數') # test.x=1 # test.y=1 # print(test.__dict__)
7.裝飾器修訂版blog
# def Typed(**kwargs): # def deco(obj): # for key,val in kwargs.items(): # # obj.key=val # setattr(obj,key,val) # return obj # return deco def Typed(**kwargs): def deco(obj): for key,val in kwargs.items(): setattr(obj,key,val) return obj return deco @Typed(x=1,y=2,z=3) class Foo: pass print(Foo.__dict__) @Typed(name='egon') class Bar: pass print(Bar.name) # @Typed(x=1,y=2,z=3) #1.Typed(x=1,y=2,z=3) --->deco 2.@deco---->Foo=deco(Foo) # class Foo: # pass # print(Foo.__dict__) # @Typed(name='egon') #@deco ---->Bar=deco(Bar) # class Bar: # pass # print(Bar.name)
8.類的裝飾器的應用字符串
# class Typed: # def __init__(self,key,expected_type): # self.key=key # self.expected_type=expected_type # def __get__(self, instance, owner): # print('get方法') # # print('instance參數【%s】' %instance) # # print('owner參數【%s】' %owner) # return instance.__dict__[self.key] # def __set__(self, instance, value): # print('set方法') # # print('instance參數【%s】' % instance) # # print('value參數【%s】' % value) # # print('====>',self) # if not isinstance(value,self.expected_type): # # print('你傳入的類型不是字符串,錯誤') # # return # raise TypeError('%s 傳入的類型不是%s' %(self.key,self.expected_type)) # instance.__dict__[self.key]=value # def __delete__(self, instance): # print('delete方法') # # print('instance參數【%s】' % instance) # instance.__dict__.pop(self.key) class Typed: def __init__(self,key,expected_type): self.key = key self.expected_type = expected_type def __get__(self, instance, owner): print('get方法') return instance.__dict__[self.key] def __set__(self, instance, value): print('set方法') if not isinstance(value,self.expected_type): raise TypeError('%s 傳入的類型不是%s'%(self.key,self.expected_type)) instance.__dict__[self.key]=value def __delete__(self, instance): print('delete方法') instance.__dict__.pop(self.key) def deco(**kwargs): def wrapper(obj): for key,val in kwargs.items(): setattr(obj,key,Typed(key,val)) return obj return wrapper @deco(name=str,age=int) class People: name = 'alex' def __init__(self,name,age,salary,gender,heigth): self.name = name self.age = age self.salary = salary print(People.__dict__) # def deco(**kwargs): #kwargs={'name':str,'age':int} # def wrapper(obj): #obj=People # for key,val in kwargs.items():#(('name',str),('age',int)) # setattr(obj,key,Typed(key,val)) # # setattr(People,'name',Typed('name',str)) #People.name=Typed('name',str) # return obj # return wrapper # @deco(name=str,age=int) #@wrapper ===>People=wrapper(People) # class People: # name='alex' # # name=Typed('name',str) # # age=Typed('age',int) # def __init__(self,name,age,salary,gender,heigth): # self.name=name # self.age=age # self.salary=salary # # p1=People('213',13.3,13.3,'x','y') # print(People.__dict__)
9.自定製classmethodget
# class ClassMethod: # def __init__(self,func): # self.func=func # def __get__(self, instance, owner): #類來調用,instance爲None,owner爲類自己,實例來調用,instance爲實例,owner爲類自己, # def feedback(*args,**kwargs): # print('在這裏能夠加功能啊...') # return self.func(owner,*args,**kwargs) # return feedback class ClassMethod: def __init__(self,func): self.func = func def __get__(self, instance, owner): def feedback(*args,**kwargs): print('在這裏能夠加功能啊...') return self.func(owner,*args,**kwargs) return feedback class People: name = 'linhaifeng' @ClassMethod def say_hi(cls,msg,x): print('你好啊,帥哥%s%s%s'%(cls,msg,x)) # People.say_hi('你那是偷心的賊',10) # class People: # name='linhaifeng' # @ClassMethod # say_hi=ClassMethod(say_hi) # def say_hi(cls,msg,x): # print('你好啊,帥哥 %s %s %s' %(cls.name,msg,x)) # # People.say_hi('你是那偷心的賊',10) # # p1=People() # p1.say_hi('你是那偷心的賊',10) p1 = People() p1.say_hi('你那是',11)
10.自定義制元類it
# class MyType(type): # def __init__(self,a,b,c): # print('元類的構造函數執行') # # print(a) # # print(b) # # print(c) # def __call__(self, *args, **kwargs): # # print('=-======>') # # print(self) # # print(args,kwargs) # obj=object.__new__(self) #object.__new__(Foo)-->f1 # self.__init__(obj,*args,**kwargs) #Foo.__init__(f1,*arg,**kwargs) # return obj # class Foo(metaclass=MyType): #Foo=MyType(Foo,'Foo',(),{})---》__init__ # def __init__(self,name): # self.name=name #f1.name=name class MyType(type): def __init__(self,a,b,c): print('元類的構造函數執行') def __call__(self, *args, **kwargs): obj = object.__new__(self) self.__init__(obj,*args,**kwargs) return obj class Foo(metaclass=MyType): def __init__(self,name): self.name = name # print(Foo) # f1 = Foo('alex') # print(f1) f1 = Foo('alex') print(f1) print(f1.__dict__) # print(Foo) # f1=Foo('alex') # print(f1) # f1=Foo('alex') # print(f1) # print(f1.__dict__)
11.自定義制元類精簡版class
# class MyType(type): # def __init__(self,a,b,c): # print('元類的構造函數執行') # def __call__(self, *args, **kwargs): # obj=object.__new__(self) # self.__init__(obj,*args,**kwargs) # return obj # class Foo(metaclass=MyType): # def __init__(self,name): # self.name=name # f1=Foo('alex') class MyType(type): def __init__(self,a,b,c): print('元類的構造函數執行') def __call__(self, *args, **kwargs): obj = object.__new__(self) self.__init__(obj,*args,**kwargs) return obj class Foo(metaclass=MyType): def __init__(self,name): self.name = name f1 = Foo('alex')