python - 无法使用装饰器打印功能的经过时间
问题描述
我创建了一个装饰器,它通过在运行程序时为给定的装饰器提供 0 毫秒的输出来计算函数所用的时间,在调试工具中它显示开始/结束时间已计算但无法打印(结束 - 开始),如图所示在代码和输出中。
我的代码:
import time
def time_cal(func):
def wrapper(*args, **kwargs):
start=time.time()
result = func(*args, **kwargs)
end= time.time()
print(func.__name__+ ' took ' + str((end-start)*1000) + ' milli seconds')
return result
return wrapper
a = (1,2,3,5,3,4,4)
b= [1,2,46,565,464]
c= {'num1': '1','num2' : '2', 'num3' : '3'}
en=[]
@time_cal
def evevn_num(i):
for i in b:
if i%2==0:
en.append(i)
else:
print("none are present")
return print(en)
@time_cal
def list_num(f,s,t):
print('number one',f)
print('number two', s)
print('number three', t)
kwargs = {"t": "Three", "s": "Two", "fs": "One"}
evevn_num(b)
list_num(1,2,3)
输出:
none are present
none are present
[2, 46, 464]
evevn_num took 0.0 milli seconds
number one 1
number two 2
number three 3
list_num took 0.0 milli seconds
Process finished with exit code 0
请根据代码帮助我解决时间计算
解决方案
您的代码按预期工作,这只是完成功能所需的速度.0013666152954102 seconds
。
要进行测试,请添加time.sleep(1)
到您的装饰器或尝试使用更复杂的功能。
def time_cal(func):
def wrapper(*args, **kwargs):
start=time.time()
time.sleep(1)
result = func(*args, **kwargs)
end= time.time()
print(func.__name__+ ' took ' + str((end-start)*1000) + ' milli seconds')
return result
return wrapper
结果:
none are present
none are present
even_num took 1009.1550350189209 milli seconds
number one 1
number two 2
number three 3
list_num took 1000.5834102630615 milli seconds
推荐阅读
- python - 跨列计算 DataFrame 中的出现次数
- jquery - 无法通过模型传输数据使用局部视图以模态加载图像
- haskell - Haskell中类型类中的异常约束
- python - 为什么使用 Keras 和 Python 对图像分类任务进行 CNN 模型训练会出错
- reactjs - 将现有的 Electron 代码库转换为 React,使其适用于移动设备
- android - 单击按钮时禁用服务重启
- ansible - 委托时使用哪个端口?在这种情况下如何指示非标准 ssh 端口?
- c# - 使用类登录表单
- https - 对来自 VB5 应用程序的 POST 请求使用 MSXML2.ServerXMLHTTP 而不是 XMLHTTP 来处理 HTTPS
- python - 如何使用 Seaborn 连接两列以在箱线图中显示为一列?