欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何實現(xiàn)一個python函數(shù)裝飾器(Decorator)

 更新時間:2020年10月12日 09:13:14   作者:半杯茶的小酒杯  
這篇文章主要介紹了如何實現(xiàn)一個python函數(shù)裝飾器(Decorator),幫助大家更好的理解和學習python,感興趣的朋友可以了解下

裝飾器本質上是一個 Python 函數(shù)或類,它可以讓其他函數(shù)或類在不需要做任何代碼修改的前提下增加額外功能,裝飾器的返回值也是一個函數(shù)/類對象。它經(jīng)常用于為已有函數(shù)/類添加記錄日志、計時統(tǒng)計、性能測試等。

首先定義一個倒計時函數(shù),這個函數(shù)的功能非常簡單,就是把n從當前值減少到0。

def countdown(n):
 while n > 0:
  print('time' + str(n))
  n -= 1

print(countdown.__name__)

程序輸出:

countdown

1.為函數(shù)增加一個日志裝飾器

假設現(xiàn)在要增強countdown的功能,在函數(shù)調用前后自動打印日志,又不想修改函數(shù)自身的功能。這種在代碼運行期間動態(tài)增加功能的方式,稱之為裝飾器(Decorator)。

能打印日志的decorator,可以定義如下:

def log(func):
  def wrapper(*args, **kw):
    print('call %s().' % func.__name__)
    return func(*args, **kw)
  return wrapper

然后我們借助Python的@語法,把decorator置于函數(shù)的定義處:

@log
def countdown(n):
 while n > 0:
  print('time:' + str(n))
  n -= 1

countdown(10)

程序輸出:

call countdown().
time:10
time:9
time:8
time:7
time:6
time:5
time:4
time:3
time:2
time:1

但此時我們再打印函數(shù)的name:

print(countdown.__name__)

程序輸出:

wrapper

我們發(fā)現(xiàn)函數(shù)的元數(shù)據(jù)信息變了,這顯然不是我們想要的結果。

2. 在裝飾器中拷貝元數(shù)據(jù)

為了把函數(shù)的元數(shù)據(jù)信息都保留下來,我們可以直接使用Python提供的functools庫中的@wraps裝飾器。

from functools import wraps

def log(func):
  @wraps(func)
  def wrapper(*args, **kw):
    print('call %s().' % func.__name__)
    return func(*args, **kw)
  return wrapper

@log
def countdown(n):
 while n > 0:
  print('time:' + str(n))
  n -= 1

print(countdown.__name__)

程序輸出:

countdown

3.為函數(shù)增加一個計時裝飾器

添加函數(shù)裝飾器的方法已經(jīng)講清楚了,現(xiàn)在再實現(xiàn)一個完整的函數(shù)計時耗時裝飾器。

import time
from functools import wraps

def TimeCost(func):
 @wraps(func)
 def wrapper(*arg, **kwargs):
  start = time.time()
  result = func(*args, **kwargs)
  end = time.time()
  print(func.__name__, end - start)
  return result
 return wrapper

@TimeCost
def countdown(n):
 while n > 0:
  print('time:' + str(n))
  n -= 1

countdown(10000)

函數(shù)輸出:

('countdown', 0.0004801750183105469)

參考資料:

https://www.liaoxuefeng.com/wiki/1016959663602400/1017451662295584

Python Cookbook中文版

以上就是如何實現(xiàn)一個python函數(shù)裝飾器(Decorator)的詳細內(nèi)容,更多關于python函數(shù)裝飾器的資料請關注腳本之家其它相關文章!

相關文章

  • Python學習筆記(一)(基礎入門之環(huán)境搭建)

    Python學習筆記(一)(基礎入門之環(huán)境搭建)

    本系列為Python學習相關筆記整理所得,IT人,多學無害,多多探索,激發(fā)學習興趣,開拓思維,不求高大上,只求懂點皮毛,作為知識儲備,不至于落后太遠。本文主要介紹Python的相關背景,環(huán)境搭建。
    2014-06-06
  • Empty test suite.(PyCharm程序運行錯誤的解決方法)

    Empty test suite.(PyCharm程序運行錯誤的解決方法)

    今天小編就為大家分享一篇Empty test suite.(PyCharm程序運行錯誤的解決方法),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11
  • ?分享一個Python?遇到數(shù)據(jù)庫超好用的模塊

    ?分享一個Python?遇到數(shù)據(jù)庫超好用的模塊

    這篇文章主要介紹了?分享一個Python?遇到數(shù)據(jù)庫超好用的模塊,SQLALchemy這個模塊,該模塊是Python當中最有名的ORM框架,該框架是建立在數(shù)據(jù)庫API之上,使用關系對象映射進行數(shù)據(jù)庫的操作,,需要的朋友可以參考下
    2022-04-04
  • Python 字符串定義

    Python 字符串定義

    字符串是程序中最常見的數(shù)據(jù)類型。在Python中,可以使用三種方式定義字符串。單引號、雙引號和三引號。
    2009-09-09
  • python模型集成知識點總結

    python模型集成知識點總結

    在本篇文章里小編給大家整理了一篇關于python模型集成知識點總結,有需要的朋友們可以學習參考下。
    2021-08-08
  • Python通過cv2讀取多個USB攝像頭

    Python通過cv2讀取多個USB攝像頭

    這篇文章主要為大家詳細介紹了Python通過cv2讀取多個USB攝像頭,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • python中的列表推導淺析

    python中的列表推導淺析

    這篇文章主要介紹了python中的列表推導,需要的朋友可以參考下
    2014-04-04
  • 用Python解數(shù)獨的方法示例

    用Python解數(shù)獨的方法示例

    這篇文章主要介紹了用Python解數(shù)獨的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • python GUI庫圖形界面開發(fā)之PyQt5下拉列表框控件QComboBox詳細使用方法與實例

    python GUI庫圖形界面開發(fā)之PyQt5下拉列表框控件QComboBox詳細使用方法與實例

    這篇文章主要介紹了python GUI庫圖形界面開發(fā)之PyQt5下拉列表框控件QComboBox詳細使用方法與實例,需要的朋友可以參考下
    2020-02-02
  • python面向對象之類屬性和類方法案例分析

    python面向對象之類屬性和類方法案例分析

    這篇文章主要介紹了python面向對象之類屬性和類方法,結合案例形式分析了Python面相對象中類屬性和類方法的相關概念、原理與使用技巧,需要的朋友可以參考下
    2019-12-12

最新評論