我的编程空间,编程开发者的网络收藏夹
学习永远不晚

掌握 Python Logging 模块的 10 个技巧

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

掌握 Python Logging 模块的 10 个技巧

1. 自定义日志级别

除了默认的 DEBUG、INFO、WARNING、ERROR 和 CRITICAL 级别,您可以创建自定义级别。这对于区分不同严重程度的事件非常有用。

import logging

# 创建自定义日志级别
CUSTOM_LEVEL = logging.INFO + 5
logging.addLevelName(CUSTOM_LEVEL, "CUSTOM")

# 创建一个 Logger 并设置自定义日志级别
logger = logging.getLogger("my_logger")
logger.setLevel(CUSTOM_LEVEL)

2. 使用不同处理器

处理器负责将日志事件发送到特定目标,如文件或控制台。您可以自定义处理器以满足您的特定需求。

import logging

# 创建一个 FileHandler 并设置日志文件名
file_handler = logging.FileHandler("my_log.txt")

# 创建一个 StreamHandler 并输出到控制台
stream_handler = logging.StreamHandler()

# 将处理器添加到 Logger
logger = logging.getLogger("my_logger")
logger.addHandler(file_handler)
logger.addHandler(stream_handler)

3. 使用过滤器

过滤器允许您根据特定条件过滤日志事件。这对于仅记录感兴趣的事件非常有用。

import logging

# 创建一个过滤器以过滤 INFO 级别以上的事件
info_filter = logging.Filter()
info_filter.filter = lambda record: record.levelno >= logging.INFO

# 将过滤器添加到 Logger
logger = logging.getLogger("my_logger")
logger.addFilter(info_filter)

4. 格式化日志输出

您可以自定义日志事件的格式,以提供所需的信息。

import logging

# 创建一个 Formatter 并设置格式字符串
formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")

# 将 Formatter 添加到处理器
handler = logging.StreamHandler()
handler.setFormatter(formatter)

# 将处理器添加到 Logger
logger = logging.getLogger("my_logger")
logger.addHandler(handler)

5. 使用上下文处理器

上下文处理器允许您在日志记录时添加额外的信息。这对于跟踪请求或事务中的上下文很有用。

import logging
from contextlib import contextmanager

# 创建一个上下文处理器以添加请求 ID
@contextmanager
def request_id_context(request_id):
    previous_request_id = logging.currentframe().f_locals.get("request_id")
    try:
        logging.currentframe().f_locals["request_id"] = request_id
        yield
    finally:
        logging.currentframe().f_locals["request_id"] = previous_request_id

# 使用上下文处理器
logger = logging.getLogger("my_logger")
with request_id_context("1234"):
    logger.info("Received request")

6. 使用字典配置

您可以使用字典轻松地配置 Logging 模块。

import logging

# 配置字典
logging_config = {
    "version": 1,
    "formatters": {
        "default": {
            "format": "%(asctime)s - %(levelname)s - %(message)s"
        }
    },
    "handlers": {
        "file": {
            "class": "logging.FileHandler",
            "filename": "my_log.txt",
            "formatter": "default",
        },
        "console": {
            "class": "logging.StreamHandler",
            "formatter": "default",
        }
    },
    "loggers": {
        "my_logger": {
            "handlers": ["file", "console"],
            "level": "INFO",
        }
    }
}

# 从字典配置 Logging
logging.config.dictConfig(logging_config)

7. 集成第三方包

Logging 模块可以与第三方包集成,例如 Sentry 或 Rollbar。这使您可以轻松地将日志事件发送到远程服务。

import logging
import sentry_sdk

# 初始化 Sentry 并与 Logging 集成
sentry_sdk.init()
logging.basicConfig(level=logging.INFO, handlers=[sentry_sdk.handler.SentryHandler()])

8. 使用多线程支持

Logging 模块支持多线程应用程序。它使用线程本地存储来确保每个线程都有其自己的独立日志处理器。

import logging
import threading

# 创建线程安全的 Logger
logger = logging.getLogger("my_logger")

# 创建一个线程并向 Logger 记录
def thread_function():
    logger.info("Executing in a separate thread")

# 启动线程
thread = threading.Thread(target=thread_function)
thread.start()

9. 记录异常

Logging 模块可以自动记录发生的异常。

import logging

# 创建一个 Logger
logger = logging.getLogger("my_logger")

# 记录一个异常
try:
    raise Exception("An error occurred")
except Exception as e:
    logger.exception(e)

10. 使用扩展日志记录

Python 3.8 引入了对扩展日志记录的支持。这允许您创建自定义日志记录函数和处理程序。

import logging

# 创建一个自定义日志记录函数
def my_log_function(logger, level, msg, *args, **kwargs):
    # 您的自定义日志记录逻辑

# 添加自定义日志记录函数到 Logger
logger = logging.getLogger("my_logger")
logger.addHandler(logging.NullHandler())
logger.addFilter(logging.Filter())
logger.log = my_log_function

免责声明:

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

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

掌握 Python Logging 模块的 10 个技巧

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

掌握 Python Logging 模块的 10 个技巧

Python Logging 模块是 Python 中一个功能强大的工具,用于管理和记录应用程序事件。掌握其技巧可以显著提高代码的调试性和可维护性。本文介绍了 10 个技巧,帮助您充分利用 Python Logging 模块。
掌握 Python Logging 模块的 10 个技巧
2024-02-20

破解 Python logging 模块的谜团:掌握其复杂性

掌握 Python logging 模块的复杂性
破解 Python logging 模块的谜团:掌握其复杂性
2024-03-06

掌握这 10 个技巧,CMS 防御 XSS 攻击不再困难!

XSS 攻击是一种常见的网络安全威胁,可以使攻击者在目标网站上执行恶意脚本。CMS(内容管理系统)是许多网站的基础,因此它们经常成为 XSS 攻击的目标。本文将介绍 10 个技巧,帮助您防御 CMS 中的 XSS 攻击。
掌握这 10 个技巧,CMS 防御 XSS 攻击不再困难!
2024-02-13

掌握C++模板编程的百变技巧

掌握 c++++ 模板编程通过使用参数化的代码块(模板)在编译时生成代码,提高代码可重用性、类型化和效率。高级技巧包括类模板特化、类型别名和函数指针。实战案例中,动态数组问题使用 dynamicarray 模板类提供了可调整大小的容器解决方
掌握C++模板编程的百变技巧
2024-05-21

Python logging 模块揭秘:掌控日志记录的艺术

Python logging 模块深入解析,掌握日志记录的奥秘,实现应用程序的全面可视化和可追溯性。
Python logging 模块揭秘:掌控日志记录的艺术
2024-03-06

Python collections模块的使用技巧

一般来讲,python的collections是用于存储数据集合(比如列表list, 字典dict, 元组tuple和集合set)的容器。这些容器内置在Python中,可以直接使用。该collections模块提供了额外的,高性能的数据类型
2022-06-02

轻松掌握PHP扩展开发技巧:创建你自己的PHP模块

本文将介绍如何创建自己的PHP模块,以便轻松掌握PHP扩展开发技巧。
轻松掌握PHP扩展开发技巧:创建你自己的PHP模块
2024-02-11

Python语言的10个小技巧分享

这篇文章主要讲解了“Python语言的10个小技巧分享”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python语言的10个小技巧分享”吧!10个Python小技巧1. 用ZIP处理列表假设
2023-06-16

快速掌握运用Python中len函数的技巧

快速掌握Python中len函数的使用技巧,需要具体代码示例Python是一种简洁、易读的编程语言,广泛应用于数据科学、机器学习、网络开发等领域。在Python中,len函数是一个非常常用且重要的函数之一。它用于返回一个对象(如字符串、列
快速掌握运用Python中len函数的技巧
2024-01-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录