如何配置使用python logging模块?

尊渡假赌尊渡假赌尊渡假赌
发布: 2025-11-28 21:16:02
原创
439人浏览过
Python logging模块用于输出调试、警告、错误等日志信息,默认仅显示WARNING及以上级别。通过logging.basicConfig可设置级别、格式及输出目标,如文件和控制台。推荐使用getLogger创建独立logger实例,自定义处理器与格式化器,实现灵活日志管理。日志级别由低到高为DEBUG、INFO、WARNING、ERROR、CRITICAL,仅记录不低于设定级别的日志。合理配置有助于提升日志可读性与维护性。

如何配置使用python logging模块?

Python 的 logging 模块是记录日志的标准方式,能帮助你输出调试信息、警告、错误等。合理配置 logging 可以让你的日志清晰、可维护,并支持输出到控制台、文件、网络等多种目标。

基本使用:快速上手

最简单的用法是直接使用模块级别的函数:

import logging
<p>logging.debug('这是一条调试信息')
logging.info('这是一条普通信息')
logging.warning('这是一个警告')
logging.error('这是一个错误')
logging.critical('这是一个严重错误')</p>
登录后复制

默认情况下,只有 WARNING 级别及以上(WARNING、ERROR、CRITICAL)会被输出到控制台,格式为:
WARNING:root:这是一个警告

如果你希望看到 debug 和 info 信息,需要先设置日志级别:

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

logging.basicConfig(level=logging.DEBUG)
登录后复制

配置日志格式和输出位置

使用 basicConfig 可以一次性配置日志的格式、输出目标、级别等:

logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
    handlers=[
        logging.FileHandler('app.log'),
        logging.StreamHandler()  # 同时输出到控制台
    ]
)
登录后复制

说明:

v3.4.0智睿报修管理系统
v3.4.0智睿报修管理系统

智睿报修管理系统定位行政企业,单位,机关加快网络无纸办公化,网络信息报修管理系统,系统支持城市区域模块管理,会员信息模块,报修种类,维修工人信息显示,达到快速准确到位,支持在线打印,数据导出,汇总数据,报修次数统计。本系统为免费版本,不收取任何费用,可直接使用。 功能模块: 权限设置 - 可设多个管理员,自由分配选项管理权限 数据备份 - 支持在线数据库备份及还原数据库 类别管理 - 支持

v3.4.0智睿报修管理系统 161
查看详情 v3.4.0智睿报修管理系统
  • level:设置最低记录级别
  • format:定义日志格式,常用占位符:
    • %(asctime)s:时间
    • %(name)s:日志器名称
    • %(levelname)s:级别名称
    • %(message)s:日志内容
  • handlers:指定多个处理器,比如写入文件和打印到控制台

使用 Logger 对象(推荐做法)

在复杂项目中,建议创建独立的 logger 实例,便于模块化管理:

logger = logging.getLogger(__name__)
logger.setLevel(logging.DEBUG)
<h1>防止重复添加 handler(重要)</h1><p>if not logger.handlers:
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')</p><pre class='brush:python;toolbar:false;'># 输出到文件
fh = logging.FileHandler('myapp.log')
fh.setFormatter(formatter)
logger.addHandler(fh)

# 输出到控制台
ch = logging.StreamHandler()
ch.setFormatter(formatter)
logger.addHandler(ch)
登录后复制

之后在代码中使用:

logger.info("程序启动")
logger.error("发生错误")
登录后复制

日志级别说明

logging 定义了五个标准级别,按严重性递增:

  • DEBUG:详细信息,用于诊断问题
  • INFO:确认程序运行正常
  • WARNING:表示可能发生的问题,但程序仍继续
  • ERROR:某个功能出错,程序部分失败
  • CRITICAL:严重错误,程序可能无法继续

只会记录 >= 当前设置级别的日志。

基本上就这些。掌握 basicConfig 和自定义 logger 就能满足大多数场景需求。关键是选择合适的级别、格式和输出方式,让日志真正有用。不复杂但容易忽略细节。

以上就是如何配置使用python logging模块?的详细内容,更多请关注php中文网其它相关文章!

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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