本文探讨了在python `logging` 配置中,当 `datefmt` 参数被错误地设置为 `datetime.now()` 的结果时,导致所有日志记录显示相同时间戳的问题。通过深入分析 `%(asctime)s` 和 `%(msecs)03d` 的工作机制,文章提供了两种解决方案:一是移除 `datefmt` 以利用默认的时间戳格式,二是通过在 `format` 字符串中显式添加 `%(msecs)03d` 来实现带有毫秒的自定义时间格式,确保日志时间戳的动态性和准确性。
在Python应用程序中,日志记录是调试、监控和故障排除的关键组成部分。logging 模块提供了高度灵活的配置选项,允许开发者自定义日志的输出格式、目的地和级别。然而,在配置日志时间戳时,一个常见的误区可能导致所有日志记录的时间戳显示为同一个值,尤其是在尝试使用 datefmt 参数来自定义时间格式时。本文将深入分析这一问题的原因,并提供两种有效的解决方案。
在 logging.Formatter 中,有两个主要的格式化字段与时间戳相关:
当在 logging 配置字典中将 datefmt 参数设置为 datetime.now().isoformat(...) 或类似的时间函数调用时,问题便会浮现。例如:
'datefmt': datetime.now().isoformat(sep='T',timespec='milliseconds')
这里的关键在于 datetime.now().isoformat(...) 表达式会在 logging_config 字典被创建(即脚本加载 logger_settings.py 文件时)的那一刻被执行一次。这意味着 datefmt 的值是一个固定的字符串,它代表了配置加载时的那个特定时间点。
因
此,所有后续的日志记录,无论它们何时发生,其 %(asctime)s 字段都会被这个固定的 datefmt 值所格式化。如果 datefmt 字符串本身不包含动态的毫秒占位符,那么所有日志条目的时间戳看起来就如同“静止”了一般,无法反映出不同日志事件之间微小的时间差异。
为了确保日志时间戳的动态性和毫秒精度,我们可以采用以下两种解决方案:
如果对时间戳的格式要求不高,并且希望 %(asctime)s 自动包含毫秒,最简单的方法是不设置 datefmt 参数,或者将其设置为 None。
示例配置:
import logging
import sys
from datetime import datetime
import time
logging_config_default_msecs = dict(
version=1,
formatters={
'verbose': {
'format': ("%(asctime)s %(levelname)s "
"[%(name)s:%(lineno)s] %(message)s"),
# 'datefmt': None # 或者直接移除此行,%(asctime)s将使用默认格式
},
'simple': {
'format': '%(asctime)s %(levelname)-8s %(message)s',
# 'datefmt': None
},
},
handlers={
'console': {
'class': 'logging.StreamHandler',
'level': 'DEBUG',
'formatter': 'verbose',
'stream': sys.stdout,
},
},
loggers={
'app_logger': {
'handlers': ['console'],
'level': logging.DEBUG,
'propagate': False
},
}
)
# 示例使用
if __name__ == '__main__':
from logging.config import dictConfig
print("--- 方案一:利用 %(asctime)s 默认毫秒精度 ---")
dictConfig(logging_config_default_msecs)
logger = logging.getLogger('app_logger')
logger.info("这是第一条日志 (方案一)")
time.sleep(0.005) # 模拟时间间隔
logger.info("这是第二条日志 (方案一)")
time.sleep(0.008)
logger.info("这是第三条日志 (方案一)")在这种配置下,%(asctime)s 将使用 logging 模块的默认格式,通常为 YYYY-MM-DD HH:MM:SS,mmm,自动包含毫秒。
如果需要自定义 datefmt 的格式(例如 ISO 8601 格式,但不希望 datefmt 自身处理毫秒),可以将 datefmt 设置为只包含年月日时分秒的格式,然后在 format 字符串中显式地添加 %(msecs)03d 来显示毫秒。这是最灵活且符合期望的解决方案,它允许你精确控制日期时间的整体格式,同时确保毫秒部分的动态性。
示例配置:
import logging
import sys
from datetime import datetime
import time
logging_config_custom_msecs = dict(
version=1,
formatters={
'verbose': {
'format': ("%(asctime)s.%(msecs)03d %(levelname)s " # 显式添加 .%(msecs)03d
"[%(name)s:%(lineno)s] %(message)s"),
'datefmt': '%Y-%m-%dT%H:%M:%S' # datefmt 只定义到秒
},
'simple': {
'format': '%(asctime)s.%(msecs)03d %(levelname)-8s %(message)s',
'datefmt': '%Y-%m-%dT%H:%M:%S'
},
},
handlers={
'file_handler': {'class': 'logging.FileHandler',
'formatter': 'verbose',
'level': logging.DEBUG,
'filename': '/tmp/logtest_'+datetime.now().strftime("%Y%m%d-%H%M%S")+'.log'},
'console': {
'class': 'logging.StreamHandler',
'level': 'DEBUG',
'formatter': 'simple',
'stream': sys.stdout,
},
},
loggers={
'app_logger': {
'handlers': ['file_handler', 'console'], # 确保引用正确的handler名称
'level': logging.DEBUG,
'propagate': False
},
}
)
# 示例使用
if __name__ == '__main__':
from logging.config import dictConfig
print("\n--- 方案二:自定义 datefmt 并显式添加 %(msecs)03d ---")
dictConfig(logging_config_custom_msecs)
logger = logging.getLogger('app_logger')
logger.info("这是第一条日志 (方案二)")
time.sleep(0.005) # 模拟时间间隔
logger.info("这是第二条日志 (方案二)")
time.sleep(0.008)
logger.info("这是第三条日志 (方案二)")在这个方案中,%(asctime)s 会按照 '%Y-%m-%dT%H:%M:%S' 格式化(只到秒),然后 .%(msecs)03d 会追加当前日志记录的毫秒数。这样既实现了自定义的日期时间格式,又确保了毫秒的动态显示。
通过采用上述解决方案,可以有效避免Python logging 中 datefmt 配置不当导致的时间戳固定问题,确保日志的准确性和实用性。
# python
# app
# ai
# stream
# 区别
# yy
# gate
相关文章:
如何制作一个表白网站视频,关于勇敢表白的小标题?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
如何在景安服务器上快速搭建个人网站?
如何选择高性价比服务器搭建个人网站?
如何通过主机屋免费建站教程十分钟搭建网站?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
高端智能建站公司优选:品牌定制与SEO优化一站式服务
Python文件管理规范_工程实践说明【指导】
济南企业网站制作公司,济南社保单位网上缴费步骤?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
高防服务器租用如何选择配置与防御等级?
建站之星3.0如何解决常见操作问题?
建站之星后台密码遗忘如何找回?
Python路径拼接规范_跨平台处理说明【指导】
如何快速搭建高效香港服务器网站?
已有域名和空间如何搭建网站?
建站主机是什么?如何选择适合的建站主机?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
大型企业网站制作流程,做网站需要注册公司吗?
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
如何选择靠谱的建站公司加盟品牌?
一键网站制作软件,义乌购一件代发流程?
如何在Golang中指定模块版本_使用go.mod控制版本号
建站主机核心功能解析:服务器选择与网站搭建流程指南
导航网站建站方案与优化指南:一站式高效搭建技巧解析
如何访问已购建站主机并解决登录问题?
如何用AWS免费套餐快速搭建高效网站?
如何在IIS中新建站点并配置端口与IP地址?
深圳网站制作案例,网页的相关名词有哪些?
济南专业网站制作公司,济南信息工程学校怎么样?
如何获取上海专业网站定制建站电话?
相册网站制作软件,图片上的网址怎么复制?
网站制作企业,网站的banner和导航栏是指什么?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
建站之星伪静态规则如何设置?
如何高效完成自助建站业务培训?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
如何用低价快速搭建高质量网站?
建站之星如何通过成品分离优化网站效率?
如何快速搭建个人网站并优化SEO?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
如何正确选择百度移动适配建站域名?
如何用狗爹虚拟主机快速搭建网站?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
建站之星备案流程有哪些注意事项?
*请认真填写需求信息,我们会在24小时内与您取得联系。