python中的装饰器和抽象类
生活随笔
收集整理的這篇文章主要介紹了
python中的装饰器和抽象类
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
裝飾器和抽象類
裝飾器就是對函數或者方法或者類進行修飾
''' #第一步:創建一個普通函數 def laxi():print('噗哧噗哧噗哧噗哧~~~')#調用函數 laxi() laxi() '''''' #第二步:擴展函數的功能(不是裝飾器) #聲明一個擴展函數 def decor(func):print('求神拜佛,祝愿一切順利')func()#相當于調用laxi()print('拉稀成功,燒香還愿') def laxi():print('噗哧噗哧噗哧噗哧~~~') #將laxi函數傳入decor函數中 laxi = decor(laxi) #調用函數 laxi() laxi() '''''' #第三步:擴展函數的功能(不是裝飾器),使用語法糖 #聲明一個擴展函數 def decor(func):print('求神拜佛,祝愿一切順利')func()#相當于調用laxi()print('拉稀成功,燒香還愿') @decor #將laxi函數傳入decor函數中#laxi = decor(laxi) def laxi():print('噗哧噗哧噗哧噗哧~~~') #調用函數 laxi() laxi() '''''' #第四步:實現基本的裝飾器 def decor(func):#函數名隨便寫#聲明內部函數來制作完整的裝飾函數def _decor():#函數名隨便寫print('求神拜佛,祝愿一切順利')func()#相當于調用laxi()print('拉稀成功,燒香還愿')return _decor @decor#laxi = decor(laxi) def laxi():print('噗哧噗哧噗哧噗哧~~~') #調用函數 laxi() laxi() laxi() laxi() '''''' #第五步:實現帶有參數和返回值的哦裝飾器 #裝飾器 def decor(func):#這就是未來的拉稀函數def _decor():print('求神拜佛,祝愿一切順利')#調用拉稀函數時接收拉稀函數本身的返回值result = func()#相當于調用laxi()print('拉稀成功,燒香還愿')#為裝飾之后的函數返回一個值return result#返回內部函數作為未來的laxi函數return _decor @decor #拉稀函數 def laxi():print('噗哧噗哧噗哧噗哧~~~')return '熱翔一碗' #調用拉稀函數 jg = laxi() print(jg) '''''' #裝飾器 def decor(func):#這就是未來的拉稀函數(原函數有什么形參,這里就要有什么形參)def _decor(who,weight):print('求神拜佛,祝愿一切順利')#調用拉稀函數時接收拉稀函數本身的返回值result = func(who,weight)#相當于調用laxi()print('拉稀成功,燒香還愿')#為裝飾之后的函數返回一個值return result#返回內部函數作為未來的laxi函數return _decor @decor #拉稀函數 def laxi(who,weight):print('噗哧噗哧噗哧噗哧~~~:'+who+'拉了'+weight+'斤便便')return '熱翔一碗' jg = laxi('馬俊龍','10') print(jg) '''''' #第六步:收集參數裝飾器(給裝飾器內部的函數加參數) def decor(func):#返回未來的拉稀函數def _decor(*who,*weight):print('求神拜佛,祝愿一切順利')result = func(*who,**weight)print('拉稀成功,燒香還愿')return result#返回裝飾之后的函數return _decor @decor def laxi(*who,**weight):print('噗哧噗哧噗哧噗哧~~~')print('參與拉屎的人有:',who)print('分別拉了多少:',weight)return '熱翔一大鍋!' #調用函數 jg = laxi('馬俊龍','閻瑞龍','霍云瑞','曹睿','宋笑寒',mjl = '5斤',yrl = '2斤',hyr= '1噸',cr = '10克',sxh = '便秘') print(jg) '''''' #第七步:帶有參數的裝飾器(給裝飾器加參數) #定義裝飾器(接收裝飾器參數) def decor(arg):#接收函數的參數def _decor(func):#未來的拉稀和吃飯函數的裝飾def __decorla():#未來的拉稀函數print('求神拜佛,祝愿一切順利')result = func()print('拉稀成功,燒香還愿')return resultdef __decorchi():#未來的吃飯函數print('我要開動了~')result = func()print('我吃完了~')return result#根據裝飾器的參數返回不同的裝飾結果if arg == 'la':return __decorlaelif arg == 'chi':return __decorchi#返回裝飾器的第一層return _decor @decor('la') def laxi():print('噗哧噗哧噗哧噗哧~~~')return '熱翔一碗' @decor('chi') def chifan():print('吧唧吧唧吧唧吧唧!~~~')return '空碗一個' #調用laxi jg = laxi() print(jg) #調用chifan jg = chifan() print(jg) '''''' #第八步:將類作為裝飾器參數傳入進來 #祝愿祈福類 class Wish:#綁定類的方法def before():print('燒香拜服,祝愿一切順利!')#綁定類的方法def after():print('拉稀成功,燒香還愿~') #裝飾器 def decor(cls):def _decor(func):#這是未來的拉稀函數def __decor():cls.before()result = func()cls.after()return result#返回裝飾之后的函數return __decorreturn _decor @decor(Wish) def laxi():print('噗哧噗哧噗哧噗哧~~~')return '熱翔一手' #調用函數 jg = laxi() print(jg) '''''' #第九步:將類作為裝飾器使用 class Decor:def __init__(self,arg):#存入對象self.arg = arg#此魔術方法用于接收原函數def __call__(self,func):#將原方法存到對象當中self.func = func#返回裝飾之后的函數return self.mylaxi#裝飾函數def mylaxi(self):print('燒香拜服,祝愿一切順利!')#調用原函數result = self.func()print('拉稀成功,燒香還愿~')return result @Decor(5) def laxi():print('噗哧噗哧噗哧噗哧~~~')return '熱翔一手' jg = laxi() print(jg) '''''' #第十步:為類添加裝飾器(單例模式) #聲明一個容器用于存放對象 obj = {}#假設存入的對象鍵名only 值為對象本身 {'only':對象} def decor(cls):#裝飾器的操作def _decor():if 'only' in obj:#對象已經創建return obj['only']else:#對象沒有創建,創建對象并返回obj['only'] = cls()return obj['only']#返回裝飾的操作return _decor #當前類只能實例化一個對象 @decor class LiXue:name = '小雪'sex = '女'age = '21歲'def stuPy():print('好好學習天天向上!') #實例化第一個對象 one = LiXue() print(one) two = LiXue() print(two) three = LiXue() print(three) ''' #第十一步:多個裝飾器嵌套 #裝飾器1 def decor1(func):def _decor1():print('脫褲子,準備放炮')result = func()print('拉屎完畢,提褲子走人~')return resultreturn _decor1 #裝飾器2 def decor2(func):def _decor2():print('燒香拜佛,祝愿一切順利!')result = func()print('操作成功,燒香還愿')return resultreturn _decor2 @decor2 @decor1 def laxi():print('撲哧撲哧撲哧撲哧撲哧~~')return '熱翔一大杯' jg = laxi() print(jg)方法的分類
類和對象的方法一共分為三種:
實例方法/對象方法
只有實例化對象之后才可以使用的方法,該方法的第一個形參接收的一定是對象本身!綁定類的方法/靜態方法
無需實例化,可以通過類直接調用的方法,方法中的參數既不接收對象名也不接受類。 一般方法可以獨立調用,跟類中其他成員關聯不大類方法
無需實例化,可以通過類直接調用的方法 但是方法的第一個參數接收的一定是類本身,這種方法一般情況下需要借助類中其他成員操作 #包含各種方法的類 class Person:#綁定類的方法,靜態方法@staticmethod #可以省略不寫def walk():print('走路方法,綁定類的方法')#非綁定類的方法 對象方法def say(self):print(self)print('說話功能,非綁定類方法')#類方法@classmethod #必須寫def drink(cls):print(cls)print('喝水方法,類方法')#調用非綁定類的方法(對象/實例方法) tw = Person() tw.say()#綁定類的方法,靜態方法 Person.walk()#調用類方法 Person.drink()抽象類
具有抽象方法的類就是抽象類。
抽象方法就是沒有完成的方法。只有方法名稱和參數,沒有方法內容的方法。
作用:適合于領導指定開發規范及多人協作完成類。
abc abstract class 抽象類的縮寫
抽象類的語法
#使用抽象類必須使用abc模塊 import abc
#書寫抽象類必須指定抽象類的元類 固定格式
class Human(metaclass = abc.ABCMeta):
@abc.abstractmethod
def smoking(self):
pass
@abc.abstractclassmethod
def say(cls):
pass
@abc.abstractstaticmethod
def cry():
pass
抽象類的特征:
1.抽象類中可以包含具體的方法也可以包含抽象方法 2.抽象類中可以包含成員屬性,而且屬性沒有抽象不抽象之分 3.抽象類無法實例化使用. 4.抽象類只能被其他類繼承使用,(唯一的用法) 5.只有子類實現了抽象類的所有抽象方法之后,該子類才可以正常實例化使用。有一個抽象方法沒有實現都不可以實例化 6.抽象類的作用是指定程序開發的標準(方法名,參數等)
多態
多態,多種狀態!就是一個類,根據不同的情況,相同的方法產生不同的結果。
總結
以上是生活随笔為你收集整理的python中的装饰器和抽象类的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SPI 协议的解析
- 下一篇: 和利时dcs系统服务器设置,和利时DCS