首頁 >後端開發 >Python教學 >Python logging 模組知識點大揭秘:常見問題一網打盡

Python logging 模組知識點大揭秘:常見問題一網打盡

王林
王林轉載
2024-03-08 08:00:14705瀏覽

Python logging 模块知识点大揭秘:常见问题一网打尽

python logging 模組基礎

logging 模組的基本原理是建立一個記錄器(logger),然後透過呼叫 logger 的方法來記錄訊息。記錄器有一個級別,它決定了將記錄哪些訊息。 logging 模組定義了幾個預先定義的級別,包括 DEBUG、INFO、WARNING、ERROR 和 CRITICAL。

import logging

# 创建一个名为 "my_logger" 的记录器,并设置其级别为 INFO
logger = logging.getLogger("my_logger")
logger.setLevel(logging.INFO)

記錄器可以透過其方法來記錄訊息:

# 记录一条 INFO 级别的消息
logger.info("This is an INFO message")

# 记录一条 WARNING 级别的消息
logger.warning("This is a WARNING message")

# 记录一条 ERROR 级别的消息
logger.error("This is an ERROR message")

日誌處理程序

日誌處理程序(handler)將日誌訊息寫入特定目標,例如控制台、檔案或網路伺服器。 logging 模組提供了幾個預先定義的處理程序:

# 创建一个控制台处理程序
handler = logging.StreamHandler()

# 创建一个文件处理程序,将日志写入文件 "my_log.txt"
handler = logging.FileHandler("my_log.txt")

處理程序可以透過新增到記錄器來附加到記錄器:

# 将处理程序添加到记录器
logger.addHandler(handler)

日誌格式器

日誌格式器(fORMatter)控制日誌訊息的外觀。 logging 模組提供了幾個預先定義的格式器:

# 创建一个基本格式器
formatter = logging.BasicFormatter()

# 使用自定义格式字符串创建自定义格式器
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")

格式器可以透過加入到處理程序來附加到處理程序:

# 将格式器添加到处理程序
handler.setFormatter(formatter)

常見問題

1. 如何在 Python 腳本中設定日誌記錄等級?

import logging

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

2. 如何記錄異常?

try:
# 尝试执行一些代码
except Exception as e:
# 记录异常
logger.error(e, exc_info=True)

3. 如何停用特定處理程序?

# 禁用控制台处理程序
logger.removeHandler(handler)

4. 如何使用自訂日誌格式?

# 使用自定义格式字符串创建自定义格式器
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")

# 将格式器添加到处理程序
handler.setFormatter(formatter)

5. 如何捕獲未捕獲的異常並將其記錄到檔案?

import sys
import logging

def exception_handler(type, value, traceback):
# 记录未捕获的异常
logger.error(value, exc_info=(type, value, traceback))

sys.excepthook = exception_handler

結論

Python logging 模組是一個功能強大的工具,可以幫助您輕鬆地記錄和處理應用程式訊息。透過掌握其關鍵知識點,您可以有效地使用 logging 模組來偵錯、故障排除和分析應用程式的行為。

以上是Python logging 模組知識點大揭秘:常見問題一網打盡的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:lsjlt.com。如有侵權,請聯絡admin@php.cn刪除