色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

一些關于python 裝飾器的個人理解

瀏覽:19日期:2022-07-12 17:28:47

裝飾器

本質是一個接受參數為函數的函數。作用:為一個已經實現的方法添加額外的通用功能,比如日志記錄、運行計時等。

舉例

1.不帶參數的裝飾器,不用@

# 不帶參數的裝飾器def deco_test(func): def wrapper(*args, **kwargs): print('before function') f = func(*args, **kwargs) print('after function') return f return wrapperdef do_something(a,b,c): print(a) time.sleep(1) print(b) time.sleep(1) print(c) return aif __name__ == ’__main__’: # 不用@ f = deco_test(do_something)('1','2','3')

輸出:

before function123after function

個人理解:

相當于在 do_something 函數外面套了兩個輸出: before function 和 after function 。

2.不帶參數的裝飾器,用 @

# 不帶參數的裝飾器def deco_test(func): def wrapper(*args, **kwargs): print('before function') f = func(*args, **kwargs) print('after function') return f return wrapper@deco_testdef do_something(a,b,c): print(a) time.sleep(1) print(b) time.sleep(1) print(c) return aif __name__ == ’__main__’: # 使用@ f = do_something('1','2','3')

輸出:

before function123after function

個人理解:

相當于執行 do_something 函數的時候,因為有 @ 的原因,已經知道有一層裝飾器 deco_test ,所以不需要再單獨寫 deco_test(do_something) 了。

3.帶參數的裝飾器

# 帶參數的裝飾器def logging(level): def wrapper(func): def inner_wrapper(*args, **kwargs): print('[{level}]: enter function {func}()'.format(level=level, func=func.__name__)) f = func(*args, **kwargs) print('after function: [{level}]: enter function {func}()'.format(level=level, func=func.__name__)) return f return inner_wrapper return wrapper@logging(level='debug')def do_something(a,b,c): print(a) time.sleep(1) print(b) time.sleep(1) print(c) return aif __name__ == ’__main__’: # 使用@ f = do_something('1','2','3')

輸出:

[debug]: enter function do_something()123after function: [debug]: enter function do_something()

個人理解:

裝飾器帶了一個參數 level = 'debug' 。

最外層的函數 logging() 接受參數并將它們作用在內部的裝飾器函數上面。內層的函數 wrapper() 接受一個函數作為參數,然后在函數上面放置一個裝飾器。這里的關鍵點是裝飾器是可以使用傳遞給 logging() 的參數的。

4.類裝飾器

# 類裝飾器class deco_cls(object): def __init__(self, func): self._func = func def __call__(self, *args, **kwargs): print('class decorator before function') f = self._func(*args, **kwargs) print('class decorator after function') return f@deco_clsdef do_something(a,b,c): print(a) time.sleep(1) print(b) time.sleep(1) print(c) return aif __name__ == ’__main__’: # 使用@ f = do_something('1','2','3')

輸出:

class decorator before function123class decorator after function

個人理解:

使用一個裝飾器去包裝函數,返回一個可調用的實例。 因此定義了一個類裝飾器。

5.兩層裝飾器

# 不帶參數的裝飾器def deco_test(func): def wrapper(*args, **kwargs): print('before function') f = func(*args, **kwargs) print('after function') return f return wrapper# 帶參數的裝飾器def logging(level): def wrapper(func): def inner_wrapper(*args, **kwargs): print('[{level}]: enter function {func}()'.format(level=level, func=func.__name__)) f = func(*args, **kwargs) print('after function: [{level}]: enter function {func}()'.format(level=level, func=func.__name__)) return f return inner_wrapper return wrapper@logging(level='debug')@deco_testdef do_something(a,b,c): print(a) time.sleep(1) print(b) time.sleep(1) print(c) return aif __name__ == ’__main__’: # 使用@ f = do_something('1','2','3')

輸出:

[debug]: enter function wrapper()before function123after functionafter function: [debug]: enter function wrapper()

個人理解:

在函數 do_something() 外面先套一層 deco_test() 裝飾器,再在最外面套一層 logging() 裝飾器。

以上就是python 裝飾器的一些個人理解的詳細內容,更多關于python 裝飾器的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产综合久久一区二区三区 | 久久精品午夜 | 综合视频在线 | 欧美日韩一区二区在线观看视频 | 真实国产精品视频国产网 | 九九久久视频 | 国产成人毛片 | 午夜精品免费 | 日韩在线二区全免费 | 在线观看国产日本 | 国产精品美女久久福利网站 | 久久99久久精品免费思思 | 网友自拍第一页 | 老司机深夜影院入口aaaa | 国产成人丝袜视频在线视频 | 亚洲精品人成网在线播放影院 | 一级毛片不卡 | 成人久久久观看免费毛片 | 自偷自偷自亚洲永久 | 欧美另类综合 | 久久亚洲国产午夜精品理论片 | 五月色婷婷综合开心网4438 | 国产95在线 | 亚洲 | 欧美在线亚洲 | 亚洲国产成人精品一区91 | 亚洲成综合 | 日韩三级黄色 | 伊人手机视频 | 一级做a爰 | 日本免费a级片 | 国产一在线精品一区在线观看 | 久久老司机波多野结衣 | 久久久久久久久久久大尺度免费视频 | 亚洲国语在线视频手机在线 | 欧美日韩视频一区二区三区 | 国产成人亚洲精品无广告 | 欧美片欧美日韩国产综合片 | 亚洲欧美精品中文字幕 | 九九热视频在线免费观看 | 国产成人在线视频免费观看 | 日韩成人精品日本亚洲 |