Python 裝飾器@,對函數(shù)進行功能擴展操作示例【開閉原則】
本文實例講述了Python 裝飾器@,對函數(shù)進行功能擴展操作。分享給大家供大家參考,具體如下:
裝飾器可以對原函數(shù)進行功能擴展,但還不需要修改原函數(shù)的內容(開閉原則),也不需要修改原函數(shù)的調用。
demo.py(裝飾器,@):
# 閉包
def w1(func):
def inner():
# 對原函數(shù)進行功能擴展
print("功能擴展")
func()
# return func() # 如果原函數(shù)需要返回值,可以return
return inner # 閉包
@w1
# 相當于 f1 = w1(f1)
def f1():
print('f1') # 原函數(shù)不需要修改
f1() # 原函數(shù)的調用也不需要修改
demo.py(裝飾器通用格式,對不定長參數(shù)并且有返回值的函數(shù)進行裝飾):
def set_func(func):
def call_func(*args, **kwargs):
print("裝飾器擴展的功能")
return func(*args, **kwargs) # 這里的*和*表示拆包。 不管有沒有返回值,return都沒問題。
return call_func
@set_func # 相當于 test1 = set_func(test1)
# 對含有不定長參數(shù)并且有返回值的函數(shù)進行裝飾。
def test1(num, *args, **kwargs):
print("-----test1----%d" % num)
return "ok"
ret = test1(100)
print(ret)
demo.py(多個裝飾器的裝飾順序):
def add_1(func):
def call_func(*args, **kwargs):
print("裝飾器1 擴展的功能")
return func(*args, **kwargs)
return call_func
def add_2(func):
def call_func(*args, **kwargs):
print("裝飾器2 擴展的功能")
return func(*args, **kwargs)
return call_func
@add_2
@add_1
# 先裝飾add_1,再裝飾add_2
def test1():
print("------test1------")
test1() # 在調用函數(shù)之前就已經裝飾好了。
# 裝飾器2 擴展的功能
# 裝飾器1 擴展的功能
# ------test1------
demo.py(用類充當裝飾器):
# 用類充當裝飾器
class Test(object):
def __init__(self, func):
self.func = func
def __call__(self, *args, **kwargs):
print("這里是裝飾器添加的功能.....")
return self.func(*args, **kwargs)
@Test # 相當于get_str = Test(get_str) # 實例化對象,調用__init__方法。
def get_str():
return "haha"
print(get_str()) # 實例對象(),會自動調用對象的__call__方法。
@functools.wraps修飾裝飾器的內層函數(shù)。(修飾內層函數(shù)后,被裝飾器裝飾的函數(shù)的__name__、__doc__不會被裝飾器改變)
demo.py(@functools.wraps修飾裝飾器的內層函數(shù)):
# coding:utf-8
import functools # 導入
# 自定義的裝飾器
def login_required(func):
@functools.wraps(func)
# 裝飾器的內層函數(shù),一般要加@functools.wraps裝飾器
def wrapper(*arg, **kwargs):
"""wrapper的說明文檔"""
# 。。。
return func(*arg, **kwargs)
return wrapper
# 使用自定義的裝飾器
@login_required
def demofunc():
"""demofunc的說明文檔"""
pass
print(demofunc.__name__) # 不加@functools.wraps裝飾器時:"wrapper"。 加裝飾器時:"demofunc"
print(demofunc.__doc__) # 不加@functools.wraps裝飾器時:"wrapper的說明文檔"。 加裝飾器時:"demofunc的說明文檔"
更多關于Python相關內容感興趣的讀者可查看本站專題:《Python面向對象程序設計入門與進階教程》、《Python數(shù)據(jù)結構與算法教程》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》、《Python編碼操作技巧總結》及《Python入門與進階經典教程》
希望本文所述對大家Python程序設計有所幫助。
- Python 中的函數(shù)裝飾器和閉包詳解
- Python高階函數(shù)與裝飾器函數(shù)的深入講解
- 如何實現(xiàn)一個python函數(shù)裝飾器(Decorator)
- Python如何創(chuàng)建裝飾器時保留函數(shù)元信息
- python裝飾器相當于函數(shù)的調用方式
- python函數(shù)裝飾器之帶參數(shù)的函數(shù)和帶參數(shù)的裝飾器用法示例
- Python函數(shù)裝飾器原理與用法詳解
- 讓你Python到很爽的加速遞歸函數(shù)的裝飾器
- Python裝飾器限制函數(shù)運行時間超時則退出執(zhí)行
- Python函數(shù)裝飾器的使用教程
相關文章
python消費kafka數(shù)據(jù)批量插入到es的方法
今天小編就為大家分享一篇python消費kafka數(shù)據(jù)批量插入到es的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12
150行Python代碼實現(xiàn)帶界面的數(shù)獨游戲
這篇文章主要介紹了150行Python代碼實現(xiàn)帶界面的數(shù)獨游戲,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04
pandas 數(shù)據(jù)結構之Series的使用方法
這篇文章主要介紹了pandas 數(shù)據(jù)結構之Series的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-06-06
Python實現(xiàn)xml格式轉txt格式的示例代碼
VOC 的標注是xml格式的,而YOLO是.txt格式,所以要實現(xiàn)VOC數(shù)據(jù)集轉YOLO數(shù)據(jù)集,只能利用代碼實現(xiàn)。所以本文為大家介紹了Python中xml轉txt的示例代碼,需要的可以參考一下2022-03-03
Python3自動簽到 定時任務 判斷節(jié)假日的實例
今天小編就為大家分享一篇Python3自動簽到 定時任務 判斷節(jié)假日的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11

