0

0

Python logging 日志模块正确使用方式

舞夢輝影

舞夢輝影

发布时间:2026-02-26 19:55:02

|

332人浏览过

|

来源于php中文网

原创

python logging模块需统一配置而非在模块中调用basicconfig();各模块应使用logging.getlogger(__name__)获取命名logger,通过propagate和setlevel精细控制日志流向与级别,并用exception()记录带traceback的异常。

python logging 日志模块正确使用方式

Python 的 logging 模块不是“print 的高级替代品”,而是需要合理配置才能真正发挥作用的系统级工具。核心原则是:不要在模块顶层直接调用 logging.basicConfig(),避免日志被重复初始化或覆盖;每个模块应使用 logging.getLogger(__name__) 获取命名 logger;日志级别、输出目标和格式应在程序入口(如 main() 或启动脚本)统一配置。

避免在模块中调用 basicConfig()

basicConfig() 只有在 root logger 尚未配置时才生效,且只能生效一次。如果多个模块各自调用,只有第一个生效,后续会被静默忽略——这会导致日志不输出、级别不生效、格式错乱等隐蔽问题。

  • ❌ 错误示例(在 utils.py 中):
import logging<br>logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')  # 不要这样写
  • ✅ 正确做法:所有配置集中在应用启动处,比如 app.py__main__.py
import logging<br><br>if __name__ == '__main__':<br>    logging.basicConfig(<br>        level=logging.DEBUG,<br>        format='%(asctime)s [%(name)s] %(levelname)-8s %(message)s',<br>        handlers=[<br>            logging.StreamHandler(),<br>            logging.FileHandler('app.log', encoding='utf-8')<br>        ]<br>    )<br>    # 启动主逻辑<br>    main()

按模块命名获取 logger,不共用 root

使用 logging.getLogger(__name__) 能自动继承 root logger 的配置,同时支持独立设置级别、添加专属 handler,便于后期按模块开关日志或分流输出。

  • database.py 中:
import logging<br><br>logger = logging.getLogger(__name__)  # 名为 'database'<br><br>def connect():<br>    logger.debug('Connecting to DB...')<br>    logger.info('Connected successfully')
  • api/handler.py 中:
logger = logging.getLogger(__name__)  # 名为 'api.handler'<br>logger.warning('Rate limit exceeded for user: %s', user_id)

这样终端里就能看到带模块前缀的日志:2024-05-20 10:30:12 [api.handler] WARNING Rate limit exceeded...

Replit Agent
Replit Agent

Replit最新推出的AI编程工具,可以帮助用户从零开始自动构建应用程序。

下载

立即学习Python免费学习笔记(深入)”;

谨慎使用 logger.setLevel() 和 propagate

子 logger 默认 propagate=True,即日志会逐级向上传递到父 logger(最终到 root)。若某个模块想屏蔽日志,不要设 logger.setLevel(logging.CRITICAL),而应设 logger.propagate = False 或调整 root 级别。

  • 常见需求与写法:
  • 仅关闭某模块日志: logging.getLogger('third_party_lib').setLevel(logging.WARNING)
  • 让某模块日志不打印到控制台(但保留文件输出):给它单独加 FileHandler,并设 propagate=False
  • 临时提高调试粒度:运行时执行 logging.getLogger('database').setLevel(logging.DEBUG)

记录异常要带完整上下文

logger.exception()logger.error('msg', exc_info=True),而不是手动拼接 str(e) ——前者会自动附加 traceback,包含行号、函数名、变量状态,对排障至关重要。

try:<br>    risky_operation()<br>except ValueError as e:<br>    logger.exception('Failed to process input')  # ✅ 自动记录 traceback<br>    # 不要写成:logger.error('Failed: %s', str(e))  ❌

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

14

2026.02.03

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

391

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

348

2023.10.25

discuz database error怎么解决
discuz database error怎么解决

discuz database error的解决办法有:1、检查数据库配置;2、确保数据库服务器正在运行;3、检查数据库表状态;4、备份数据;5、清理缓存;6、重新安装Discuz;7、检查服务器资源;8、联系Discuz官方支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

2023.11.20

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

1

2026.02.26

Golang Web 开发路线:构建高效后端服务
Golang Web 开发路线:构建高效后端服务

《Golang Web 开发路线:构建高效后端服务》围绕 Go 在后端领域的工程实践,系统讲解 Web 框架选型、路由设计、中间件机制、数据库访问与接口规范,结合高并发与可维护性思维,逐步构建稳定、高性能、易扩展的后端服务体系,帮助开发者形成完整的 Go Web 架构能力。

3

2026.02.26

Golang 并发编程专题:掌握多核时代的核心技能
Golang 并发编程专题:掌握多核时代的核心技能

《Golang 并发编程专题:掌握多核时代的核心技能》系统讲解 Go 在并发领域的设计哲学与实践方法,深入剖析 goroutine、channel、调度模型与并发安全机制,结合真实场景与性能思维,帮助开发者构建高吞吐、低延迟、可扩展的并发程序,全面提升多核时代的工程能力。

5

2026.02.26

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

353

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号