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

posted @   楚千羽  阅读(137)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示