返回顶部
首页 > 资讯 > 后端开发 > Python >Python Logging 模块使用指南:解决常见问题
  • 0
分享到

Python Logging 模块使用指南:解决常见问题

Python 官方文档:入门教程 => 点击学习

摘要

python Logging、记录、调试、监控 解决常见问题 1. 如何设置基本配置? import logging # 设置基本配置 logging.basicConfig( level=logging.INFO,

python Logging、记录、调试、监控

解决常见问题

1. 如何设置基本配置?

import logging

# 设置基本配置
logging.basicConfig(
    level=logging.INFO,
    fORMat="%(asctime)s %(levelname)s: %(message)s"
)

2. 如何使用不同的日志级别?

logging.debug("这是一个调试消息")
logging.info("这是一个信息消息")
logging.warning("这是一个警告消息")
logging.error("这是一个错误消息")
logging.critical("这是一个严重错误消息")

3. 如何创建自定义记录器?

# 创建一个名为 "my_custom_logger" 的记录器
my_logger = logging.getLogger("my_custom_logger")
my_logger.setLevel(logging.INFO)

# 创建一个文件处理程序
file_handler = logging.FileHandler("my_app.log")
file_handler.setLevel(logging.INFO)

# 创建一个流处理程序
stream_handler = logging.StreamHandler()
stream_handler.setLevel(logging.INFO)

# 为记录器添加处理程序
my_logger.addHandler(file_handler)
my_logger.addHandler(stream_handler)

my_logger.info("这是一个自定义记录的消息")

4. 如何配置日志格式?

logging.basicConfig(
    level=logging.INFO,
    format="[%(asctime)s] %(levelname)s %(name)s: %(message)s"
)

5. 如何使用日志过滤器?

# 创建一个过滤器,仅记录来自 "my_custom_logger" 记录器的警告消息
my_filter = logging.Filter()
my_filter.filter = lambda record: record.name == "my_custom_logger" and record.levelno == logging.WARNING

# 为记录器添加过滤器
my_logger.addFilter(my_filter)

6. 如何捕获 unhandled 异常?

import sys

# 为 unhandled 异常设置一个处理程序
logging.basicConfig(
    level=logging.ERROR,
    format="[%(asctime)s] %(levelname)s %(name)s: %(message)s",
    handlers=[logging.StreamHandler(sys.stderr)]
)

# 触发一个 unhandled 异常
raise Exception("这是一个 unhandled 异常")

7. 如何启用 thread-safe 日志记录?

import logging
import threading

# 为 thread-safe 日志记录设置一个处理程序
logging.basicConfig(
    level=logging.INFO,
    format="[%(asctime)s] %(levelname)s %(name)s: %(message)s",
    handlers=[logging.StreamHandler()],
    concurrent=True
)

# 创建一个线程并记录消息
def my_thread():
    logging.info("这是一个来自线程的消息")

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

8. 如何配置 logging 配置文件?

创建一个名为 "logging.conf" 的文件,并将其放置在应用程序目录中:

[loggers]
keys=root

[handlers]
keys=console

[formatters]
keys=simple

[logger_root]
level=INFO
handlers=console

[handler_console]
class=StreamHandler
level=INFO
formatter=simple

[formatter_simple]
format=%(asctime)s - %(name)s - %(levelname)s - %(message)s

在应用程序中导入配置:

import logging.config

# 导入 logging 配置文件
logging.config.fileConfig("logging.conf")

--结束END--

本文标题: Python Logging 模块使用指南:解决常见问题

本文链接: https://lsjlt.com/news/566250.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作