Python中的裝飾器使用
Python裝飾器用法
Python的裝飾器是個好東西,它能干很多事情。
但對于新手,它看起來似乎沒那么簡單。
但事實上,裝飾器本身也只是個函數(shù)。
import time
def log(func):
? ? def wrapper(*args, **kwargs):
? ? ? ? start = time.time()
? ? ? ? result = func(*args, **kwargs)
? ? ? ? end = time.time()
? ? ? ? print("The func '{}' used {}s.".format(func.__name__, end-start))
? ? ? ? return result
? ? return warpper這一個裝飾器,當(dāng)我們這樣使用時
@log
def fucok(name):
? ? """Fucok someone"""
? ? print("Fucok", name)它只是執(zhí)行了fucok = log(fucok)這樣一句代碼而已。
也就是說,我們表面上是用fucok("myself"),事實上執(zhí)行的都是log(fucok)("myself")。因為Python里面都是對象嘛。
同樣的道理,假設(shè)我們定義了一個帶參數(shù)的裝飾器logging,它實際上執(zhí)行的是
func = logging(arguments)(func)
也就是上面那個不帶參數(shù)的裝飾器多定義一層就行了。
import time
def logging(arguments):
? ? def log(func):
? ? ? ? def warpper(*args, **kwargs):
? ? ? ? ? ? start = time.time()
? ? ? ? ? ? result = func(*args, **kwargs)
? ? ? ? ? ? end = time.time()
? ? ? ? ? ? print("The func '{}' used {}s.".format(func.__name__, end-start))
? ? ? ? ? ? return result
? ? ? ? return warpper
? ? # do something
? ? return log但,當(dāng)我們使用一個裝飾器之后,它會將原本的函數(shù)元信息給覆蓋掉。譬如:函數(shù)名稱,函數(shù)文檔等等。
例如上例
print(fucok.__name__) print(fucok.__doc__)
你會發(fā)現(xiàn),函數(shù)信息全部沒了!fucok它不叫fucok,改名叫wrapper了。它的文檔也變成了none。
解決辦法很簡單,定義裝飾器的時候用warps裝飾器裝飾接受原函數(shù)參數(shù)的那一層就行了。
這個來自functools模塊的裝飾器能幫你復(fù)制函數(shù)的元信息到被綁定的函數(shù)身上。
修改裝飾器如下(其實就加了一行代碼hhh)
import time
from functools import wraps
def log(func):
? ? @wraps(func)
? ? def warpper(*args, **kwargs):
? ? ? ? start = time.time()
? ? ? ? result = func(*args, **kwargs)
? ? ? ? end = time.time()
? ? ? ? print("The func '{}' used {}s.".format(func.__name__, end-start))
? ? ? ? return result
? ? return warpper當(dāng)我們再運行
print(fucok.__name__) print(fucok.__doc__)
就能看到函數(shù)的的元信息沒變了。
裝飾器定義時加@wraps是個好習(xí)慣。
一個較為實用的裝飾器demo在該專題的另一篇文章:函數(shù)參數(shù)類型檢查
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
python3.9和pycharm的安裝教程并創(chuàng)建簡單項目的步驟
這篇文章主要介紹了python3.9和pycharm的安裝教程并創(chuàng)建簡單項目的步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
python如何實現(xiàn)數(shù)據(jù)的線性擬合
這篇文章主要為大家詳細介紹了python如何實現(xiàn)數(shù)據(jù)的線性擬合,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07
OpenCV結(jié)合selenium實現(xiàn)滑塊驗證碼
本文主要介紹了OpenCV結(jié)合selenium實現(xiàn)滑塊驗證碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08

