python 主动统计方法耗时

import time
from types import FunctionType


class CalcTime:
    def __init__(self,name='') -> None:
        self.t=0
        if(isinstance(name,FunctionType)):
            self.name=name
        else:
            self.name=str(name)

    def __enter__(self):
        print('in')
        self.t=time.time()
    def __exit__(self, type, value, trace):
        v=round((time.time()-self.t)*1000)
        print('out',self.name,v)
    def __call__(self, *args, **kwds) :
        t=time.time()
        try:
            self.name(*args,**kwds)
        except Exception as e:
            v=round((time.time()-t)*1000)
            print('out',self.name.__name__,v)
            raise e
        v=round((time.time()-t)*1000)
        print('out',self.name.__name__,v)


with CalcTime('test') :
    time.sleep(0.1)
    pass

@CalcTime
def ttt(a):
    time.sleep(1)
    print(a)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值