gpt4 book ai didi

python-3.x - Python日志模块 - 自上次日志以来的时间

转载 作者:行者123 更新时间:2023-12-03 16:06:41 25 4
gpt4 key购买 nike

我想在 Python 的日志记录模块生成的日志中添加自最后一次进入日志以来耗时(秒/毫秒)。

这很有用,因此您可以查看日志文件以查看同一步骤是否总是花费相同的时间或变化,表明环境中发生了某些变化(例如数据库性能)。

我知道 %(relativeCreated)d,但这仅显示自记录器启动以来耗时,而不是自上次创建日志以来的时间。
基本上 %(relativeCreated)d 是累积值,我想看到的是每个 %(relativeCreated)d 之间的差异。

这就是您使用 %(relativeCreated)d 得到的结果:

2015-07-20 12:31:07,037 (7ms) - INFO - Process started....
2015-07-20 12:31:07,116 (87ms) - INFO - Starting working on xyz
2015-07-20 12:31:07,886 (857ms) - INFO - Progress so far

这就是我需要的:
2015-07-20 12:31:07,037 (duration: 7ms) - INFO - Process started....
2015-07-20 12:31:07,116 (duration: 80ms) - INFO - Starting working on xyz
2015-07-20 12:31:07,886 (duration: 770ms) - INFO - Progress so far

最佳答案

扩展@Simeon Visser 的答案——过滤器是一个简单的存储设备,用于存储自脚本启动以来最后一条消息的相对时间(参见self.last 类中的TimeFilter)。

import datetime
import logging

class TimeFilter(logging.Filter):

def filter(self, record):
try:
last = self.last
except AttributeError:
last = record.relativeCreated

delta = datetime.datetime.fromtimestamp(record.relativeCreated/1000.0) - datetime.datetime.fromtimestamp(last/1000.0)

record.relative = '{0:.2f}'.format(delta.seconds + delta.microseconds/1000000.0)

self.last = record.relativeCreated
return True

然后将该过滤器应用于每个日志处理程序并访问每个日志处理程序的日志格式字符串中的相对时间。
fmt = logging.Formatter(fmt="%(asctime)s (%(relative)ss) %(message)s")
log = logging.getLogger()
[hndl.addFilter(TimeFilter()) for hndl in log.handlers]
[hndl.setFormatter(fmt) for hndl in log.handlers]

关于python-3.x - Python日志模块 - 自上次日志以来的时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31521859/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com