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

Python實(shí)現(xiàn)屬性可修改的裝飾器方式

 更新時(shí)間:2024年02月09日 10:02:00   作者:AllardZhao  
這篇文章主要介紹了Python實(shí)現(xiàn)屬性可修改的裝飾器方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

如何實(shí)現(xiàn)屬性可修改的函數(shù)裝飾器

實(shí)際案例

為分析程序內(nèi)哪些函數(shù)執(zhí)行時(shí)間開銷比較大,

我們定義一個(gè)帶timeout參數(shù)的函數(shù)裝飾器,timeout是一個(gè)時(shí)間閥值

比如運(yùn)行時(shí)間超過1秒的都是比較慢的,這種函數(shù)比較可疑。

裝飾器功能如下:

  • 統(tǒng)計(jì)被裝飾函數(shù)單詞調(diào)用運(yùn)行時(shí)間;
  • 時(shí)間大于參數(shù)timeout的,將此次函數(shù)調(diào)用記錄到log日志中;
  • 運(yùn)行時(shí)可修改timeout的值(可以動(dòng)態(tài)修改timeout)。

解決方案

為包裹函數(shù)增加一個(gè)函數(shù)作為包裹函數(shù)的屬性,用來修改閉包中使用的自由變量。

在python3中:使用nonlocal訪問嵌套作用域中的變量引用。

代碼演示

# _*_ encoding:utf-8 _*_
from functools import wraps
from random import randint
import time
import logging
 
 
# 內(nèi)部統(tǒng)計(jì)一個(gè)算法的運(yùn)行時(shí)間
def warn(timeout):
    """ 帶參數(shù)裝飾器也就是內(nèi)部能返回一個(gè)裝飾器 """
    # python2中因?yàn)闆]有nonlocal,可以將timeout聲明為可變對(duì)象
    # timeout = [timeout]
 
    # 裝飾器冬季func運(yùn)行時(shí)間
    def decorator(func):
        # 定義包裹函數(shù)
        def wrapper(*args, **kwargs):
            start = time.time()
            res = func(*args, **kwargs)
            # 得到運(yùn)行時(shí)間
            used = time.time() - start
            if used > timeout:
                msg = '"%s": %s > %s' % (func.__name__, used, timeout)
                # 如果超時(shí)輸入到日志當(dāng)中
                logging.warning(msg)
            # if used > timeout[0]:
            #     msg = '"%s": %s > %s' % (func.__name__, used, timeout[0])
            #     logging.warn(msg)
            # return res
 
        #  動(dòng)態(tài)修改函數(shù)屬性timeout值
        def set_timeout(k):
            # python3聲明嵌套作用域下變量,類似于global
            nonlocal timeout
            timeout = k
            # python2中使用可變對(duì)象修改timeout
            # timeout[0] = k
 
        # 將set_timeout函數(shù)作為wrapper屬性,未來用戶就可以通過函數(shù)來調(diào)用到它。
        wrapper.set_timeout = set_timeout
        return wrapper
 
    return decorator
 
 
# 測(cè)試代碼
@warn(1.5)
def test():
    print('In test')
    # 隨機(jī)進(jìn)入睡眠狀態(tài),百分之50概率
    while randint(0, 1):
        time.sleep(0.5)
 
 
for _ in range(30):
    test()
 
# 測(cè)試運(yùn)行時(shí)修改timeout屬性等于1
test.set_timeout(1)
for _ in range(30):
    test()
 
'''
運(yùn)行完前30個(gè)test函數(shù)后修改timeout=1。
運(yùn)行時(shí)可以看到timeout從1.5變成了1,如下:
WARNING:root:"test": 1.509084939956665 > 1.5
WARNING:root:"test": 1.004662036895752 > 1
'''

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python的ORM框架中SQLAlchemy庫的查詢操作的教程

    Python的ORM框架中SQLAlchemy庫的查詢操作的教程

    這篇文章主要介紹了Python的ORM框架中SQLAlchemy庫的查詢操作的教程,SQLAlchemy用來操作數(shù)據(jù)庫十分方便,需要的朋友可以參考下
    2015-04-04
  • 使用python實(shí)現(xiàn)掃描端口示例

    使用python實(shí)現(xiàn)掃描端口示例

    這篇文章主要介紹了使用python實(shí)現(xiàn)掃描端口示例,需要的朋友可以參考下
    2014-03-03
  • python3中宏HAVE_VFORK的使用

    python3中宏HAVE_VFORK的使用

    本文主要介紹了python3中宏HAVE_VFORK的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Python序列操作之進(jìn)階篇

    Python序列操作之進(jìn)階篇

    序列sequence是python中最基本的數(shù)據(jù)結(jié)構(gòu),本文是Python序列操作的進(jìn)階篇,本文先對(duì)序列做一個(gè)簡(jiǎn)單的概括,之后將詳細(xì)講解下關(guān)于序列的操作方法。文中通過示例代碼介紹的很詳細(xì),有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • python pyppeteer 破解京東滑塊功能的代碼

    python pyppeteer 破解京東滑塊功能的代碼

    這篇文章主要介紹了python pyppeteer 破解京東滑塊功能的代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • 一些關(guān)于python 裝飾器的個(gè)人理解

    一些關(guān)于python 裝飾器的個(gè)人理解

    這篇文章主要介紹了python 裝飾器的一些理解,希望可以幫助大家更好的學(xué)習(xí)和使用python,感興趣的朋友可以了解下
    2020-08-08
  • Python使用defaultdict讀取文件各列的方法

    Python使用defaultdict讀取文件各列的方法

    這篇文章主要介紹了Python使用defaultdict讀取文件各列的方法,涉及Python針對(duì)文件相關(guān)讀取、遍歷操作技巧,需要的朋友可以參考下
    2017-05-05
  • tensorflow實(shí)現(xiàn)從.ckpt文件中讀取任意變量

    tensorflow實(shí)現(xiàn)從.ckpt文件中讀取任意變量

    這篇文章主要介紹了tensorflow實(shí)現(xiàn)從.ckpt文件中讀取任意變量,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Python實(shí)現(xiàn)自定義異常實(shí)例

    Python實(shí)現(xiàn)自定義異常實(shí)例

    大家好,本篇文章主要講的是Python實(shí)現(xiàn)自定義異常實(shí)例,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Python?Plotly庫安裝及使用教程

    Python?Plotly庫安裝及使用教程

    這篇文章主要介紹了包括安裝、導(dǎo)入庫、Plotly的基本結(jié)構(gòu)、常見圖表類型、樣式定制以及如何與Pandas數(shù)據(jù)框結(jié)合使用,通過示例代碼和解釋,幫助讀者快速掌握Plotly的使用技巧,需要的朋友可以參考下
    2025-03-03

最新評(píng)論