文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python logging 模块解密:揭示其不为人知的一面

2024-03-06 05:18

关注

1. 日志级别:精准控制日志信息

logging 模块定义了五种标准日志级别:DEBUG、INFO、WARNING、ERROR 和 CRITICAL。这些级别决定了要记录的消息的重要性和严重性。默认情况下,logging 仅记录 WARNING 及以上级别的消息。您可以通过设置日志器的级别来微调日志的行为。例如:

import logging

# 设置 root 日志器的级别为 INFO
logging.basicConfig(level=logging.INFO)

2. 日志格式:定制日志输出

logging 模块提供了强大的日志格式机制,允许您自定义日志消息的外观。格式字符串指定了日志消息中包含的信息,例如时间戳、日志级别、消息文本和堆栈跟踪。默认格式为:

"[%(asctime)s] %(levelname)s %(module)s.%(funcName)s: %(message)s"

您可以使用以下代码自定义格式:

# 设置自定义日志格式
logging.basicConfig(format="%(asctime)s %(levelname)-8s %(message)s")

3. 日志处理器:扩展日志输出目的地

处理器负责将日志消息发送到特定目标,例如文件、控制台或远程服务器。logging 模块提供了几种内置处理器,如 StreamHandler 和 FileHandler。

创建自定义处理器也非常简单。您需要创建一个类并覆盖 handle 方法,该方法将日志消息写入目标。例如,将日志写入自定义文件:

class MyFileHandler(logging.FileHandler):
    def __init__(self, filename):
        super().__init__(filename)

# 将自定义处理器添加到 root 日志器
logging.getLogger().addHandler(MyFileHandler("my_log.txt"))

4. 日志筛选器:过滤不必要的日志消息

筛选器允许您根据特定的条件过滤日志消息。您可以基于日志级别、消息文本或其他标准来创建筛选器。筛选器可以附加到处理器,以仅允许满足条件的消息通过。

例如,忽略 WARNING 级别的消息的筛选器:

import logging

# 创建筛选器忽略 WARNING 级别的消息
filter = logging.Filter()
filter.filter = lambda record: record.levelno < logging.WARNING

# 将筛选器添加到 root 日志器的处理器
logging.getLogger().handlers[0].addFilter(filter)

5. 日志上下文管理:优雅的日志记录

logging.LoggerContextManager 上下文管理器提供了一种简洁的方式来记录块中的消息。这对于临时更改日志级别或禁用日志记录非常有用。

with logging.LoggerContextManager():
    # 临时将日志级别设置为 DEBUG
    logging.getLogger().setLevel(logging.DEBUG)

    # 在块内记录 DEBUG 级的消息
    logging.debug("调试信息")

6. 高级技巧:

结论:

Python logging 模块是一个功能强大的工具,可用于有效地记录应用程序活动。通过理解日志级别、日志格式、日志处理器、日志筛选器和高级技巧,您可以充分利用 logging 的功能,为您的应用程序创建灵活且有意义的日志记录解决方案。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯