Python教程

Python装饰器记录函数被调用次数和最大值

本文主要是介绍Python装饰器记录函数被调用次数和最大值,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

@counter为装饰器

.num记录被装饰函数被调用的次数

.numberr记录被装饰函数里指定变量在所有被调用次数中的最大值,例如

number变量第一次被调用时值是2
number变量第二次被调用时值是5
number变量第三次被调用时值是20
number变量第四次被调用时值是18
number变量第五次被调用时值是9
一共调用5次,最终.numberr值为 20

# -*- coding: utf-8 -*-
# @Time : 2022/6/6 0:06
# @Author : chuqianyu
# @FileName: test00.py
# @Software: PyCharm
# @Blog :https://home.cnblogs.com/u/chuqianyu
from functools import wraps

def counter(func):
    @wraps(func)
    def tmp(*args, **kwargs):
        tmp.count += 1
        return func(*args, **kwargs)
    tmp.count = 0
    tmp.numberr = 0
    return tmp

@counter
def foo(x):
    print('foo:'+str(2*x))
    if 2*x > foo.numberr:
        foo.numberr = 2*x
    print(foo.count)
    print(foo.numberr)

foo(1)
# print(foo.count)    # 1
# print(foo.numberr)  # 2


foo(10)
# print(foo.count)    # 2
# print(foo.numberr)  # 20


foo(5)
# print(foo.count)    # 3
# print(foo.numberr)  # 30

运行结果:
image

这篇关于Python装饰器记录函数被调用次数和最大值的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!