Python 裝飾器原理、定義與用法詳解
本文實例講述了Python 裝飾器原理、定義與用法。分享給大家供大家參考,具體如下:
Python 裝飾器
一、何為裝飾器
1、在函數(shù)中定義函數(shù)
在函數(shù)中定義另外的函數(shù),就是說可以創(chuàng)建嵌套的函數(shù),例子如下
def sayHi(name="hjj2"): print 'inside sayHi() func' def greet(): return 'inside greet() func' print(greet()) sayHi() #output # inside sayHi() func # inside greet() func
2、將函數(shù)作為參數(shù)傳給另外一個函數(shù),裝飾器原型
def sayHi(): return 'hi hjj2' def doSthBeforeSayHi(func): print 'before sayHi func' print(func()) doSthBeforeSayHi(sayHi) #output # before sayHi func # hi hjj2
3、實現(xiàn)一個裝飾器
在第二步中,我們已經(jīng)基本探究到裝飾器的原理了,python裝飾器做的事就是通過封裝一個函數(shù)并且用這樣或那樣的方式來修改它的行為。不帶@的初步示例如下:
def new_decorator(func): def wrapDecorator(): print 'before func' func() print 'after func' return wrapDecorator def func_require_decorator(): print 'a func need decorator' func_require_decorator() #ouput: a func need decorator func_require_decorator = new_decorator(func_require_decorator) func_require_decorator() #ouput: # before func # a func need decorator # after func
使用@來運行裝飾器
@new_decorator func_require_decorator() #ouput: # before func # a func need decorator # after func
這里我們可以看到,這兩個例子的運行結(jié)果是一樣的。所以我們能想象得到@new_decorator的作用就是
func_require_decorator = new_decorator(func_require_decorator)
我們繼續(xù)優(yōu)化這個裝飾器,現(xiàn)在我們有一個問題就是,如果我們想要通過print(func_require_decorator.__name__)就會報錯# Output: wrapTheFunction。這樣就需要借助python提供的functools.wraps來解決了
@wraps接受一個函數(shù)來進(jìn)行裝飾,并加入了復(fù)制函數(shù)名稱、注釋文檔、參數(shù)列表等等的功能。這可以讓我們在裝飾器里面訪問在裝飾之前的函數(shù)的屬性。
from functools import wraps def new_decorator(func): @wraps(func) def wrapDecorator(): print 'before func' func() print 'after func' return wrapDecorator def func_require_decorator(): print 'a func need decorator' @new_decorator func_require_decorator() print(func_require_decorator.__name__) #ouput: func_require_decorator
二、使用場景
1、授權(quán),大體例子
from functools import wraps
def requires_auth(f):
@wraps(f)
def decorated(*args, **kwargs):
auth = request.authorization
if not auth or not check_auth(auth.username, auth.password):
authenticate()
return f(*args, **kwargs)
return decorated
2、日志:
from functools import wraps
def logit(logfile='out.log'):
def logging_decorator(func):
@wraps(func)
def wrapped_function(*args,**kwargs):
log_string = func.__name__+"was called"
print(log_string)
with open(logfile,'a') as opened_file:
opened_file.write(log_string+'\n')
return func(*args,**kwargs)
return wrapped_function
return logging_decorator
@logit()
def func1():
pass
func1()
3、其他如flask中的@app.route()
三、裝飾器類
1、將上面的日志裝飾器變?yōu)轭惖某醪侥P腿缦?/strong>
from functools import wraps
class logit(object):
def __init__(self, logfile='out.log'):
self.logfile = logfile
def __call__(self, func):
@wraps(func)
def wrapped_function(*args, **kwargs):
log_string = func.__name__ + "was called"
print(log_string)
# 打開logfile并寫入
with open(self.logfile, 'a') as open_file:
# 將日志寫到指定文件
open_file.write(log_string + '\n')
# 發(fā)送一個通知
self.notify()
return func(*args, **kwargs)
return wrapped_function
def notify(self):
pass
@logit()
def myfunc1():
pass
class email_logit(logit):
'''
實現(xiàn)在函數(shù)調(diào)用時發(fā)送email
'''
def __init__(self, email='admin@xxx.com', *args, **kwargs):
self.email = email
super(email_logit, self).__init__(*args, **kwargs)
def notify(self):
'''
發(fā)送郵件通知
'''
pass
通過這種方式,我們可以定義我們在自己的需求,減少代碼的冗余,提高復(fù)用率。
至此,關(guān)于裝飾器的探索就結(jié)束啦。
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python面向?qū)ο蟪绦蛟O(shè)計入門與進(jìn)階教程》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python編碼操作技巧總結(jié)》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
python的xpath獲取div標(biāo)簽內(nèi)html內(nèi)容,實現(xiàn)innerhtml功能的方法
今天小編就為大家分享一篇python的xpath獲取div標(biāo)簽內(nèi)html內(nèi)容,實現(xiàn)innerhtml功能的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01
python筆記_將循環(huán)內(nèi)容在一行輸出的方法
今天小編就為大家分享一篇python筆記_將循環(huán)內(nèi)容在一行輸出的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
pyCharm 設(shè)置調(diào)試輸出窗口中文顯示方式(字符碼轉(zhuǎn)換)
這篇文章主要介紹了pyCharm 設(shè)置調(diào)試輸出窗口中文顯示方式(字符碼轉(zhuǎn)換),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
Pytorch之tensorboard無法啟動和顯示問題及解決
這篇文章主要介紹了Pytorch之tensorboard無法啟動和顯示問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09
使用Python編程分析火爆全網(wǎng)的魷魚游戲豆瓣影評
本文來為大家介紹如何使用Python爬取影評的操作,主要是爬取《魷魚游戲》在豆瓣上的一些影評,對數(shù)據(jù)做一些簡單的分析,用數(shù)據(jù)的角度重新審視下這部劇,有需要的朋友可以借鑒參考下2021-10-10
Python數(shù)據(jù)分析:手把手教你用Pandas生成可視化圖表的教程
今天小編就為大家分享一篇Python數(shù)據(jù)分析:手把手教你用Pandas生成可視化圖表的教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12

