目錄
日誌記錄等級
配置日誌記錄
日誌記錄訊息
日誌記錄過濾器
結論
首頁 後端開發 Python教學 Python logging 模組揭秘:掌控日誌記錄的藝術

Python logging 模組揭秘:掌控日誌記錄的藝術

Mar 07, 2024 pm 09:55 PM
標準函式庫

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

python logging 模組簡介

logging 模組是 Python 標準函式庫中強大的日誌記錄工具。它提供了一種標準化、可配置的方式來記錄應用程式事件、錯誤和偵錯資訊。透過使用 logging 模組,開發人員可以輕鬆追蹤應用程式行為,簡化故障排除並提高程式碼品質。

日誌記錄等級

logging 模組定義了幾個日誌記錄等級,用於指示訊息的重要性:

  • DEBUG:調試信息,用於記錄詳細的應用程式行為。
  • INFO:常規訊息,用於記錄應用程式正常操作。
  • WARNING:警告訊息,用於記錄潛在問題。
  • ERROR:錯誤訊息,用於記錄應用程式錯誤。
  • CRITICAL:嚴重錯誤訊息,用於記錄會中斷應用程式的關鍵錯誤。

配置日誌記錄

logging 模組允許透過多種方式配置日誌記錄行為:

根記錄器:

#
import logging

# 创建根记录器
root_logger = logging.getLogger()

# 设置日志记录级别
root_logger.setLevel(logging.INFO)

# 添加控制台处理程序
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.DEBUG)
console_handler.setFORMatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))
root_logger.addHandler(console_handler)

# 添加文件处理程序
file_handler = logging.FileHandler("my_app.log")
file_handler.setLevel(logging.WARNING)
file_handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))
root_logger.addHandler(file_handler)
登入後複製

自訂記錄器:

#
# 创建自定义记录器
my_logger = logging.getLogger("my_app.module1")

# 设置日志记录级别
my_logger.setLevel(logging.DEBUG)

# 添加流处理程序
stream_handler = logging.StreamHandler()
stream_handler.setLevel(logging.INFO)
stream_handler.setFormatter(logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s"))
my_logger.addHandler(stream_handler)
登入後複製

日誌記錄訊息

配置好日誌記錄設定後,開發人員可以使用以下方法記錄訊息:

  • debug()
  • #info()
  • #warning()
  • #error()
  • #critical()

#每個方法接收一個字串訊息,並在指定的日誌記錄等級下記錄該訊息。

my_logger.info("应用程序已启动")
登入後複製

日誌記錄過濾器

logging 模組提供了一種機制來過濾日誌訊息,僅記錄滿足特定條件的訊息。過濾器可以基於日誌記錄等級、訊息文字或其他自訂標準。

# 创建一个过滤日志记录级别的过滤器
level_filter = logging.Filter()
level_filter.filter = lambda record: record.levelno >= logging.WARNING

# 将过滤器添加到记录器
my_logger.addFilter(level_filter)
登入後複製

結論

Python logging 模組是記錄應用程式事件和偵錯資訊的強大工具。透過了解其功能和配置選項,開發人員可以設計健壯且可維護的應用程式。透過全面視覺化應用程式行為,logging 模組有助於提高程式碼品質、簡化故障排除並增強偵錯流程。

以上是Python logging 模組揭秘:掌控日誌記錄的藝術的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

_complex在c語言中的用法 _complex在c語言中的用法 May 08, 2024 pm 01:27 PM

complex 類型用於表示 C 語言中的複數,包含實部和虛部。其初始化形式為 complex_number = 3.14 + 2.71i,實部可透過 creal(complex_number) 訪問,虛部可透過 cimag(complex_number) 存取。此類型支援常用的數學運算,如加、減、乘、除和取模。此外,還提供了一組用於處理複數的函數,如 cpow、csqrt、cexp 和 csin。

c++中prime什麼意思 c++中prime什麼意思 May 07, 2024 pm 11:33 PM

prime 是 C++ 中的關鍵字,表示質數類型,只能被 1 和本身整除,用作布林類型指示給定值是否為質數,為質數則為 true,否則為 false。

c++中fabs是什麼意思 c++中fabs是什麼意思 May 08, 2024 am 01:15 AM

fabs() 函數是 C++ 中的一個數學函數,用於計算浮點數的絕對值,去除負號並傳回正值。它接受一個浮點參數,並傳回一個 double 類型的絕對值。例如,fabs(-5.5) 將傳回 5.5。此函數適用於浮點數,其精確度受底層硬體影響。

c++中std::怎麼用 c++中std::怎麼用 May 09, 2024 am 03:45 AM

std 是 C++ 中包含標準函式庫元件的命名空間。為了使用 std,需要使用 "using namespace std;" 語句。直接使用 std 命名空間中的符號可以簡化程式碼,但建議僅在需要時使用,以避免命名空間污染。

c++中min是什麼意思 c++中min是什麼意思 May 08, 2024 am 12:51 AM

C++ 中的 min 函數可傳回多個值中的最小值。其語法為:min(a, b),其中 a 和 b 為要比較的值。也可以指定一個比較函數,以支援不支援 < 運算子的類型。 C++20 引入了 std::clamp 函數,可處理三個或更多值的最小值。

C++ 智慧指標:全面剖析其生命週期 C++ 智慧指標:全面剖析其生命週期 May 09, 2024 am 11:06 AM

C++智慧指標的生命週期:建立:分配記憶體時建立智慧指標。所有權轉移:透過移動操作轉移所有權。釋放:智慧指標離開作用域或被明確釋放時釋放記憶體。物件銷毀:所指向物件被銷毀時,智慧型指標成為無效指標。

prime在c++中是什麼意思 prime在c++中是什麼意思 May 07, 2024 pm 11:24 PM

在 C++ 中,prime 指質數,即大於 1 且只能被 1 和它本身整除的自然數。質數在密碼學、數學問題和演算法中應用廣泛。產生質數的方法包括厄拉多塞篩法、費馬小定理和米勒-拉賓檢定。 C++ 標準函式庫中提供 isPrime 函數判斷是否為質數,nextPrime 函數傳回大於給定值的最小質數,prevPrime 函數傳回小於給定值的最小質數。

c語言中abs的意思 c語言中abs的意思 May 08, 2024 pm 12:18 PM

c 語言中的 abs() 函數用於計算整數或浮點數的絕對值,即它與零點的距離,始終為非負數。它接收一個數字參數,並傳回該數字的絕對值。

See all articles