博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python使用上下文对代码片段进行计时,非装饰器
阅读量:7144 次
发布时间:2019-06-29

本文共 633 字,大约阅读时间需要 2 分钟。

之前发过了一组常用的装饰器,包括了一个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} 秒')

 

 

 测试下:

 

 

 

转载地址:http://negrl.baihongyu.com/

你可能感兴趣的文章
安装淘宝镜像cnpm时出现问题及解决方案
查看>>
POJ-3255 Roadblocks---Dijkstra队列优化+次短路
查看>>
Sublime Text快捷键
查看>>
用Ant实现Java项目的自动构建和部署(转)
查看>>
[react] React 新手必须知道的 N 件事
查看>>
高精度阶乘计算(蓝桥杯)
查看>>
C++标准不允许拷贝构造函数传值参数
查看>>
异常 中断 实现
查看>>
001C#基本语法
查看>>
初识python: 集合
查看>>
noip rp++
查看>>
php mysql PDO使用
查看>>
python学习(七)--豆瓣爬取电影名,评分以及演员
查看>>
Android ImageView(scaleType属性)
查看>>
[AHOI2008]上学路线
查看>>
VS2013的项目转到VS2010需要修改的
查看>>
1.6.1 三角形
查看>>
CAS 集群部署
查看>>
HDU.2111 Saving HDU(贪心)
查看>>
sqlmap用户手册
查看>>