Python 裝飾器代碼解析
前言:
以往看到我博客的小伙伴可能都知道,我的前言一般都是吐槽和講廢話環(huán)節(jié),哈哈哈哈。今天難得休息,最近可真是太忙了,博主已經(jīng)連續(xù)一年都在996了,所以最近沒怎么學(xué)習(xí)新東西,只能回顧以往的舊知識了,上周一起工作的小伙伴扛不住996離職了,我們?nèi)说男F(tuán)隊(duì)也正式解散了,哎。原本想著找時(shí)間好好整理一個(gè)關(guān)于關(guān)于接口自動(dòng)化測試或ceph相關(guān)的東西。但由于篇幅過長這里目前可能不會著手寫這方面東西。其實(shí)啊寫是很簡單的,主要例子難找。哈哈哈哈。
好了回歸正題吧??催^我以往博客的小伙伴肯定見我用過@parameterized.expand()用作參數(shù)化的裝飾器。這屬于系統(tǒng)定義裝飾器,當(dāng)然我們自己也可以自定義裝飾器已適合我們?nèi)粘5拈_發(fā)需求。
**什么是裝飾器:**裝飾器的本質(zhì)就是一個(gè)函數(shù),作用是在不改變源代碼的情況下,給函數(shù)增加額外的功能;裝飾器的使用通過@語法糖進(jìn)行調(diào)用。
普通裝飾器:
直接上代碼吧。
def demo(func_test):
def wrapper():
print('定義的第一個(gè)裝飾器')
func_test()
print('裝飾器結(jié)束')
return wrapper #這里注意不要加括號
@demo
def func_test():
print('小白小白?。。。?)

直接使用自定義裝飾器強(qiáng)化的原方法。
帶有參數(shù)的裝飾器:
def demo(func_test):
def wrapper(name):
print('定義的第一個(gè)裝飾器')
func_test(name)
print('哦,你就是%s啊'%name)
print('裝飾器結(jié)束')
return wrapper
@demo
def func_test(name):
print('大家好我叫%s'%name)

是不是有點(diǎn)感覺了啊。
接下來就是不帶自定義參數(shù)的裝飾器
def demo(func_test):
def wrapper(*name,**kwargs):
print('定義的第一個(gè)裝飾器')
func_test(*name,**kwargs)
print('哦,你就是%s啊'%name[0])
print('你今年%s歲啊'%name[1])
print('裝飾器結(jié)束')
return wrapper
@demo
def func_test(name,age):
print('大家好我叫%s'%name)
print('今年{}'.format(age))

是不是很簡答啊。哈哈哈哈
多個(gè)裝飾一起使用。
def deco01(func):
def wrapper(*args,**kwargs):
print('第一層的裝飾器')
func(*args,**kwargs)
print('第一層裝飾器結(jié)束')
return wrapper
def deco02(func):
def wrapper(*args,**kwargs):
print('這是第二層裝飾器')
print('第二層裝飾器結(jié)束')
func(*args, **kwargs)
return wrapper
@deco02
@deco01
def func(a,b,c,name):
print('hello ,here is a func')
print("result is %d" %(a+b+c))
print('name:{}'.format(name))

看看執(zhí)行順序可以看出裝飾器是從上往下執(zhí)行的。
類裝飾器:
在使用裝飾器時(shí)我們總不能在一個(gè)文件里寫的都是裝飾器和各個(gè)方法吧,總是要分開的。這里就要是講一個(gè)類裝飾器。
這里呢,我大概了寫了一個(gè)讀取文件裝飾器的例子。
class Mydecorator():
def __init__(self,func):
# 定義為私有屬性
self.func = func
# 實(shí)現(xiàn)__call__方法,讓對象變成可以調(diào)用的對象,可調(diào)用的對象可以想函數(shù)那樣使用
def __call__(self, *args, **kwargs):
print('測試類裝飾器')
self.func(*args)
catalogue = args[0]
suffix = catalogue.split('.')[2]
try:
if suffix == 'json':
with open(*args,'r',encoding='utf-8') as file_object:
contents = json.load(file_object)
print(contents)
else:
with open(*args,'r',encoding='utf-8') as file_object:
contents = file_object.read()
print(contents)
except Exception as a:
print('讀取文件出錯(cuò)拉:{}'.format(a))
@Mydecorator
def name(name):
print('請輸入對應(yīng)文件路徑:%s'%name)

是不是很好用啊。哈哈哈哈
到此這篇關(guān)于Python 裝飾器代碼解析的文章就介紹到這了,更多相關(guān)Python 裝飾器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
pygame實(shí)現(xiàn)鍵盤的連續(xù)監(jiān)控
這篇文章主要為大家詳細(xì)介紹了pygame實(shí)現(xiàn)鍵盤的連續(xù)監(jiān)控,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
Python學(xué)習(xí)思維導(dǎo)圖(必看篇)
下面小編就為大家?guī)硪黄狿ython學(xué)習(xí)思維導(dǎo)圖(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06
Python pandas自定義函數(shù)的使用方法示例
這篇文章主要介紹了Python pandas自定義函數(shù)的使用方法,結(jié)合實(shí)例形式分析了pandas模塊相關(guān)自定義函數(shù)數(shù)值運(yùn)算操作技巧,需要的朋友可以參考下2019-11-11

