詳解Python裝飾器的四種定義形式
前言
裝飾器(decorator)在Python框架中扮演著重要角色,是Python中實現(xiàn)切面編程(AOP)的重要手段。
aspect-oriented programming (AOP) ,在不改變代碼自身的前提下增加程序功能
不改變代碼自身,但需要在函數(shù)和類頭上加一個標注(annotation),這個標注在Python里叫裝飾器,在java里叫注解。
在Python里,一共有四種組合形式。下面一一舉例。
用函數(shù)裝飾函數(shù)
采用一個函數(shù)定義裝飾器:
def decorate(f):
def wrapper(*args):
return f(*args)*2
return wrapper然后作用在一個函數(shù)上:
@decorate def add(a, b): return a + b
測試一下效果:
def test_decorate(): sum = add(3, 5) assert sum == 16
用函數(shù)裝飾一個類
這里通過裝飾器實現(xiàn)單例模式:
def singleton(cls):
instances = {}
def wrapper(*args, **kwargs):
if cls not in instances:
instances[cls] = cls(*args, **kwargs)
return instances[cls]
return wrapper使用該裝飾器:
@singleton
class MyClass:
def method(self):
pass于是,當你定義多個對象時,返回的是同一實例:
obj = MyClass() # creates a new instance obj2 = MyClass() # returns the same instance obj3 = MyClass() # returns the same instance ...
用類定義裝飾器,然后裝飾一個函數(shù)
先采用類定義一個裝飾器:
class Star:
def __init__(self, n):
self.n = n
def __call__(self, fn):
@wraps(fn)
def wrapper(*args, **kwargs):
result = fn(*args, **kwargs)
return result
return wrapper再作用在一個函數(shù)上:
@Star(5)
def add(a, b):
return a + b主要是在類中實現(xiàn)__call__方法。上面例子也可以簡化:
class MyDecorator:
def __init__(self, function):
self.function = function
def __call__(self, *args, **kwargs):
# We can add some code
# before function call
self.function(*args, **kwargs)
# We can also add some code
# after function call.
# adding class decorator to the function
@MyDecorator
def function(name, message ='Hello'):
print("{}, {}".format(message, name))用類定義裝飾器,然后裝飾一個類
先定義裝飾器:
class MyClassDecorator(object):
_instances = dict()
def __init__(self, name):
pass
def __call__(self, cls):
class WrappedClass(cls):
def say_hello(self):
print(f'Hello: {self.username}')
return WrappedClass該裝飾器給被裝飾的類上添加了一個方法,名稱為say_hello()。使用如下:
@MyClassDecorator('test')
class MyClass():
def __init__(self, username):
self.username = username然后:
def test_decoratorforclass():
obj = MyClass('user1')
obj.say_hello()打印出: Hello: user1
小結(jié)
學習類裝飾,對Python的內(nèi)部機制會有更多的了解。如__init__, call, __new__等內(nèi)置方法。
到此這篇關(guān)于Python裝飾器的四種定義形式的文章就介紹到這了,更多相關(guān)Python裝飾器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pandas數(shù)據(jù)類型自行變換及數(shù)據(jù)類型轉(zhuǎn)換失敗問題分析與解決
這篇文章主要介紹了Pandas數(shù)據(jù)類型自行變換及數(shù)據(jù)類型轉(zhuǎn)換失敗問題分析與解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
Python虛擬環(huán)境virtualenv創(chuàng)建及使用過程圖解
這篇文章主要介紹了Python虛擬環(huán)境virtualenv創(chuàng)建及使用過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-12-12
淺談Python 字符串格式化輸出(format/printf)
下面小編就為大家?guī)硪黄獪\談Python 字符串格式化輸出(format/printf)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07
Python編寫可視化界面的全過程(Python+PyCharm+PyQt)
這篇文章主要給大家介紹了關(guān)于Python編寫可視化界面的相關(guān)資料,主要使用了Python+PyCharm+PyQt,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2021-05-05
Python中optionParser模塊的使用方法實例教程
這篇文章主要介紹了Python中optionParser模塊的使用方法,功能非常強大,需要的朋友可以參考下2014-08-08

