婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 如何正確理解python裝飾器

如何正確理解python裝飾器

熱門標簽:地圖標注視頻廣告 北京電信外呼系統靠譜嗎 洪澤縣地圖標注 無錫客服外呼系統一般多少錢 梅州外呼業務系統 高德地圖標注是免費的嗎 老人電話機器人 大連crm外呼系統 百度地圖標注位置怎么修改

一、閉包

要想了解裝飾器,首先要了解一個概念,閉包。什么是閉包,一句話說就是,在函數中再嵌套一個函數,并且引用外部函數的變量,這就是一個閉包了。光說沒有概念,直接上一個例子。

def outer(x):
    def inner(y):
        return x + y
    return inner

print(outer(6)(5))
-----------------------------
>>>11

如代碼所示,在outer函數內,又定義了一個inner函數,并且inner函數又引用了外部函數outer的變量x,這就是一個閉包了。在輸出時,outer(6)(5),第一個括號傳進去的值返回inner函數,其實就是返回6 + y,所以再傳第二個參數進去,就可以得到返回值,6 + 5。

二、裝飾器

接下來就講裝飾器,其實裝飾器就是一個閉包,裝飾器是閉包的一種應用。什么是裝飾器呢,簡言之,python裝飾器就是用于拓展原來函數功能的一種函數,這個函數的特殊之處在于它的返回值也是一個函數,使用python裝飾器的好處就是在不用更改原函數的代碼前提下給函數增加新的功能。使用時,再需要的函數前加上@demo即可。

def debug(func):
    def wrapper():
        print("[DEBUG]: enter {}()".format(func.__name__))
        return func()
    return wrapper

@debug
def hello():
    print("hello")

hello()
-----------------------------
>>>[DEBUG]: enter hello()
>>>hello

例子中的裝飾器給函數加上一個進入函數的debug模式,不用修改原函數代碼就完成了這個功能,可以說是很方便了。

三、帶參數的裝飾器

上面例子中的裝飾器是不是功能太簡單了,那么裝飾器可以加一些參數嗎,當然是可以的,另外裝飾的函數當然也是可以傳參數的。

def logging(level):
    def outwrapper(func):
        def wrapper(*args, **kwargs):
            print("[{0}]: enter {1}()".format(level, func.__name__))
            return func(*args, **kwargs)
        return wrapper
    return outwrapper

@logging(level="INFO")
def hello(a, b, c):
    print(a, b, c)

hello("hello,","good","morning")
-----------------------------
>>>[INFO]: enter hello()
>>>hello, good morning

如上,裝飾器中可以傳入參數,先形成一個完整的裝飾器,然后再來裝飾函數,當然函數如果需要傳入參數也是可以的,用不定長參數符號就可以接收,例子中傳入了三個參數。

四、類裝飾器

裝飾器也不一定只能用函數來寫,也可以使用類裝飾器,用法與函數裝飾器并沒有太大區別,實質是使用了類方法中的__call__魔法方法來實現類的直接調用。

class logging(object):
    def __init__(self, func):
        self.func = func

    def __call__(self, *args, **kwargs):
        print("[DEBUG]: enter {}()".format(self.func.__name__))
        return self.func(*args, **kwargs)

@logging
def hello(a, b, c):
    print(a, b, c)

hello("hello,","good","morning")
-----------------------------
>>>[DEBUG]: enter hello()
>>>hello, good morning

類裝飾器也是可以帶參數的,如下實現

class logging(object):
    def __init__(self, level):
        self.level = level

    def __call__(self, func):
        def wrapper(*args, **kwargs):
            print("[{0}]: enter {1}()".format(self.level, func.__name__))
            return func(*args, **kwargs)
        return wrapper
        
@logging(level="TEST")
def hello(a, b, c):
    print(a, b, c)

hello("hello,","good","morning")
-----------------------------
>>>[TEST]: enter hello()
>>>hello, good morning

好了,如上就是裝飾器的一些概念和大致的用法啦,想更深入的了解裝飾器還是需要自己在平時的練習和應用中多體會

以上就是如何正確理解python裝飾器的詳細內容,更多關于python裝飾器的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • python中有函數重載嗎
  • 在Python中實現函數重載的示例代碼
  • python裝飾器原理源碼示例分析
  • Python Pytest裝飾器@pytest.mark.parametrize詳解
  • 理解python中裝飾器的作用
  • 詳解Python裝飾器 給你的咖啡加點料
  • python 裝飾器的使用與要點
  • 如何利用飾器實現 Python 函數重載

標簽:怒江 泉州 長春 吉林 洛陽 岳陽 安慶 清遠

巨人網絡通訊聲明:本文標題《如何正確理解python裝飾器》,本文關鍵詞  如何,正確理解,python,裝飾,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何正確理解python裝飾器》相關的同類信息!
  • 本頁收集關于如何正確理解python裝飾器的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 南华县| 东乌| 依兰县| 辽中县| 迁西县| 舞阳县| 乡城县| 裕民县| 大姚县| 普安县| 汶上县| 福海县| 灌南县| 江口县| 宜章县| 改则县| 班戈县| 凤冈县| 资中县| 大姚县| 庄河市| 巴青县| 南澳县| 荣成市| 绥化市| 大同市| 马公市| 安丘市| 洪洞县| 永仁县| 姜堰市| 三门峡市| 泰兴市| 元阳县| 陵川县| 南皮县| 辉南县| 康定县| 喀什市| 越西县| 开江县|