码迷,mamicode.com
首页 > 编程语言 > 详细

python使用上下文对代码片段进行计时,非装饰器

时间:2018-08-22 21:56:01      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:方法   filename   ext   name   frame   常用   style   manage   行记录   

之前发过了一组常用的装饰器,包括了一个where_is_it_called的装饰器,可以计时和对入参和返回结果,被何处调用进行记录,十分强大。

 

这是用上下文,上下文的好处是,不需要抽成函数才能计时。

 

class TimerContextManager(object):
    """
    用上下文管理器计时,可对代码片段计时
    """
    log = LogManager(TimerContext).get_logger_and_add_handlers()

    def __enter__(self):
        self._line = sys._getframe().f_back.f_lineno  # 调用此方法的代码的函数
        self._file_name = sys._getframe(1).f_code.co_filename  # 哪个文件调了用此方法
        self.time_start = time.time()

    def __exit__(self, exc_type, exc_val, exc_tb):
        t_spend = time.time() - self.time_start
        self.log.debug(f对下面代码片段进行计时:  \n执行"{self._file_name}:{self._line}" 用时 {t_spend} 秒)

 

 

 测试下:

技术分享图片

 

 

技术分享图片

 

python使用上下文对代码片段进行计时,非装饰器

标签:方法   filename   ext   name   frame   常用   style   manage   行记录   

原文地址:https://www.cnblogs.com/ydf0509/p/9520145.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!