zoukankan      html  css  js  c++  java
  • python使用上下文对代码片段进行计时,非装饰器

    之前发过了一组常用的装饰器,包括了一个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'对下面代码片段进行计时:  
    执行"{self._file_name}:{self._line}" 用时 {t_spend} 秒')

     测试下:

  • 相关阅读:
    P1012拼数
    P1622释放囚犯
    P1064 金明的预算方案
    P1754球迷购票问题
    卡塔兰数
    P1474货币系统
    P2562kitty猫基因
    P3984高兴的津津
    5-servlet简介
    java通过百度AI开发平台提取身份证图片中的文字信息
  • 原文地址:https://www.cnblogs.com/ydf0509/p/9520145.html
Copyright © 2011-2022 走看看