欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中l(wèi)ogger包的詳細(xì)使用教程(附實(shí)例代碼)

 更新時(shí)間:2025年05月28日 08:26:33   作者:SunkingYang  
Python?logging模塊是標(biāo)準(zhǔn)庫日志工具,支持多級(jí)別、多目標(biāo)、多格式日志管理,這篇文章主要介紹了python中l(wèi)ogger包詳細(xì)使用的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

Python 的 logging 模塊是標(biāo)準(zhǔn)庫中用于記錄日志的核心工具,通過靈活配置可實(shí)現(xiàn)多級(jí)別、多目標(biāo)、多格式的日志管理。以下是其核心用法及詳細(xì)說明:

功能說明

一、Logger 的創(chuàng)建與基礎(chǔ)配置

  • 創(chuàng)建 Logger 實(shí)例使用 logging.getLogger(name) 創(chuàng)建或獲取一個(gè) Logger 對(duì)象。若未指定名稱,默認(rèn)返回根 Logger(root)。

    import logging
    logger = logging.getLogger('my_app')  # 創(chuàng)建名為 'my_app' 的 Logger
    
  • 設(shè)置日志級(jí)別Logger 的級(jí)別決定其處理的最低日志等級(jí),可選級(jí)別從低到高為:DEBUG、INFOWARNING、ERROR、CRITICAL

    logger.setLevel(logging.DEBUG)  # 記錄 DEBUG 及以上級(jí)別的日志
    
  • 默認(rèn)級(jí)別與繼承關(guān)系

    • 若未顯式設(shè)置級(jí)別,Logger 會(huì)繼承父級(jí)(如 root)的級(jí)別,默認(rèn) WARNING。
    • Logger 名稱支持層級(jí)結(jié)構(gòu)(如 a.b 繼承 a 的配置),便于模塊化日志管理。

二、Handler 的配置與使用

Handler 負(fù)責(zé)將日志發(fā)送到不同目標(biāo)(如文件、控制臺(tái)),可同時(shí)添加多個(gè) Handler 實(shí)現(xiàn)多路輸出。

常用 Handler 類型

Handler功能示例
StreamHandler輸出到控制臺(tái)(默認(rèn) sys.stderrlogging.StreamHandler()
FileHandler輸出到文件logging.FileHandler('app.log', mode='a')
RotatingFileHandler日志文件按大小回滾(避免文件過大)from logging.handlers import RotatingFileHandler
TimedRotatingFileHandler按時(shí)間回滾日志文件(如每天生成新文件)from logging.handlers import TimedRotatingFileHandler

示例:同時(shí)輸出到文件和控制臺(tái)

# 文件 Handler(按大小回滾)
from logging.handlers import RotatingFileHandler
file_handler = RotatingFileHandler(
    'app.log', maxBytes=1024*1024, backupCount=5  # 單個(gè)文件最大1MB,保留5個(gè)備份
)
file_handler.setLevel(logging.INFO)

# 控制臺(tái) Handler
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.DEBUG)

# 添加 Handler 到 Logger
logger.addHandler(file_handler)
logger.addHandler(console_handler)

三、Formatter 自定義日志格式

通過 Formatter 可定義日志輸出的格式,支持占位符如 %(asctime)s(時(shí)間)、%(levelname)s(級(jí)別)、%(message)s(消息)等。

formatter = logging.Formatter(
    '%(asctime)s - %(name)s - %(levelname)s - %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S'  # 自定義時(shí)間格式
)
file_handler.setFormatter(formatter)
console_handler.setFormatter(formatter)

四、記錄不同級(jí)別的日志

通過 Logger 對(duì)象調(diào)用對(duì)應(yīng)級(jí)別的方法記錄日志:

logger.debug('調(diào)試信息,用于開發(fā)階段追蹤細(xì)節(jié)')    # 僅當(dāng) Logger 級(jí)別 ≤ DEBUG 時(shí)輸出
logger.info('常規(guī)信息,如服務(wù)啟動(dòng)')              
logger.warning('潛在問題警告,如參數(shù)缺失')        
logger.error('程序錯(cuò)誤,但應(yīng)用仍可運(yùn)行')          
logger.critical('嚴(yán)重錯(cuò)誤,可能導(dǎo)致程序崩潰')     

五、高級(jí)配置與最佳實(shí)踐

  • 全局配置快速啟動(dòng)使用 logging.basicConfig() 快速配置根 Logger,適合簡(jiǎn)單場(chǎng)景:

    logging.basicConfig(
        level=logging.INFO,
        format='%(asctime)s - %(message)s',
        handlers=[logging.FileHandler('app.log'), logging.StreamHandler()]
    )
    
  • 過濾器(Filter)通過 Filter 實(shí)現(xiàn)更精細(xì)的日志篩選,例如僅記錄特定模塊或包含關(guān)鍵字的日志:

    class CustomFilter(logging.Filter):
        def filter(self, record):
            return 'important' in record.getMessage()  # 僅記錄含 'important' 的日志
    
    logger.addFilter(CustomFilter())
    
  • 避免重復(fù)日志若 Logger 層級(jí)配置不當(dāng),可能導(dǎo)致日志重復(fù)輸出。建議在子 Logger 中禁用傳播到父級(jí):

    child_logger = logging.getLogger('my_app.sub_module')
    child_logger.propagate = False  # 阻止日志傳遞給父 Logger
    

六、常見問題與調(diào)試

  • 日志不顯示:檢查 Logger 和 Handler 的級(jí)別是否高于日志調(diào)用級(jí)別。
  • 多 Handler 沖突:確保每個(gè) Handler 的級(jí)別和 Formatter 獨(dú)立配置。
  • 性能優(yōu)化:高頻日志場(chǎng)景可使用 RotatingFileHandler 避免文件過大,或異步日志庫(如 concurrent-log-handler)。

以下是 Python 中 logging 模塊的詳細(xì)使用教程,涵蓋基礎(chǔ)配置、高級(jí)用法及最佳實(shí)踐,結(jié)合多篇權(quán)威資料整理而成:

使用方法

一、基礎(chǔ)配置與快速使用

  • 引入模塊與基礎(chǔ)配置通過 basicConfig() 函數(shù)快速配置全局日志參數(shù):

    import logging
    
    logging.basicConfig(
        level=logging.DEBUG,  # 設(shè)置最低日志級(jí)別為 DEBUG
        format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
        datefmt='%Y-%m-%d %H:%M:%S',  # 時(shí)間格式
        filename='app.log',  # 輸出到文件(默認(rèn)追加模式)
        filemode='w'  # 覆蓋模式寫入文件(可選)
    )
    
  • 記錄不同級(jí)別的日志使用預(yù)定義的日志級(jí)別方法輸出信息:

    logging.debug('調(diào)試信息')    # 開發(fā)階段追蹤細(xì)節(jié)
    logging.info('常規(guī)狀態(tài)')    # 程序正常運(yùn)行信息
    logging.warning('潛在問題')  # 如參數(shù)缺失或兼容性問題
    logging.error('錯(cuò)誤事件')    # 功能異常但程序仍運(yùn)行
    logging.critical('嚴(yán)重故障') # 系統(tǒng)可能崩潰的致命錯(cuò)誤
    

    注意:只有不低于 level 參數(shù)設(shè)置的級(jí)別才會(huì)被記錄。

二、自定義 Logger 對(duì)象

  • 創(chuàng)建獨(dú)立 Logger推薦為不同模塊創(chuàng)建獨(dú)立 Logger 以分類管理日志:

    logger = logging.getLogger('my_module')  # 名稱建議使用模塊名
    logger.setLevel(logging.INFO)  # 覆蓋全局級(jí)別
    
  • 添加處理器(Handler)支持同時(shí)輸出到控制臺(tái)、文件、網(wǎng)絡(luò)等多種目標(biāo):

    # 控制臺(tái)處理器
    console_handler = logging.StreamHandler()
    console_handler.setLevel(logging.DEBUG)
    
    # 文件處理器(按大小輪轉(zhuǎn))
    from logging.handlers import RotatingFileHandler
    file_handler = RotatingFileHandler(
        'app.log', maxBytes=10*1024*1024, backupCount=5  # 10MB/文件,保留5個(gè)備份
    )
    file_handler.setLevel(logging.ERROR)
    
    # 將處理器附加到 Logger
    logger.addHandler(console_handler)
    logger.addHandler(file_handler)
    
  • 自定義日志格式通過 Formatter 定義日志輸出樣式:

    formatter = logging.Formatter(
        '%(asctime)s [%(levelname)s] %(module)s:%(lineno)d - %(message)s',
        datefmt='%H:%M:%S'
    )
    console_handler.setFormatter(formatter)
    file_handler.setFormatter(formatter)
    

三、高級(jí)用法

  • 配置文件管理使用 .conf 或 .ini 文件分離配置(推薦大型項(xiàng)目):

    import logging.config
    
    logging.config.fileConfig('logging.conf')
    

    示例 logging.conf 內(nèi)容

    [loggers]
    keys=root,my_app
    
    [handlers]
    keys=consoleHandler,fileHandler
    
    [formatters]
    keys=simpleFormatter
    
    [logger_root]
    level=DEBUG
    handlers=consoleHandler
    
    [logger_my_app]
    level=INFO
    handlers=fileHandler
    qualname=my_app
    propagate=0  # 禁止傳播到父級(jí) Logger
    
  • 日志傳播控制通過 propagate 屬性控制是否向父級(jí) Logger 傳遞日志:

    child_logger = logging.getLogger('parent.child')
    child_logger.propagate = False  # 僅當(dāng)前 Logger 處理日志
    
  • 過濾器(Filter)實(shí)現(xiàn)精細(xì)化日志篩選:

    class KeywordFilter(logging.Filter):
        def __init__(self, keyword):
            super().__init__()
            self.keyword = keyword
    
        def filter(self, record):
            return self.keyword in record.getMessage()
    
    logger.addFilter(KeywordFilter('重要'))
    

四、最佳實(shí)踐與注意事項(xiàng)

  • 性能優(yōu)化

    • 避免高頻日志調(diào)用:使用 isEnabledFor() 檢查級(jí)別后再記錄:
      if logger.isEnabledFor(logging.DEBUG):
          logger.debug(f'耗時(shí)計(jì)算: {expensive_function()}')
      
    • 使用異步日志庫(如 concurrent-log-handler)處理高并發(fā)場(chǎng)景。
  • 多環(huán)境配置根據(jù)運(yùn)行環(huán)境動(dòng)態(tài)調(diào)整配置:

    if os.getenv('ENV') == 'production':
        logger.setLevel(logging.WARNING)
    else:
        logger.setLevel(logging.DEBUG)
    
  • 錯(cuò)誤處理為關(guān)鍵操作添加異常捕獲并記錄堆棧:

    try:
        risky_operation()
    except Exception as e:
        logger.exception('操作失敗: %s', e)  # 自動(dòng)記錄堆棧跟蹤
    

五、實(shí)際應(yīng)用場(chǎng)景示例

網(wǎng)絡(luò)請(qǐng)求監(jiān)控

import requests

def fetch_data(url):
    try:
        response = requests.get(url, timeout=5)
        response.raise_for_status()
        logger.info(f'成功獲取 {url} 數(shù)據(jù)')
        return response.json()
    except requests.RequestException as e:
        logger.error(f'請(qǐng)求失敗: {url} - {str(e)}')
        return None

通過合理配置 Logger、Handler 和 Formatter,可以構(gòu)建靈活高效的日志系統(tǒng)。更多高級(jí)功能(如遠(yuǎn)程日志、郵件通知)可參考 Python 官方文檔

總結(jié)

到此這篇關(guān)于python中l(wèi)ogger包詳細(xì)使用的文章就介紹到這了,更多相關(guān)python logger包使用教程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Python開啟線程和線程池的方法

    詳解Python開啟線程和線程池的方法

    這篇文章主要介紹了Python開啟線程和線程池的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-03-03
  • python 爬蟲之selenium可視化爬蟲的實(shí)現(xiàn)

    python 爬蟲之selenium可視化爬蟲的實(shí)現(xiàn)

    這篇文章主要介紹了python 爬蟲之selenium可視化爬蟲的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Python 一鍵制作微信好友圖片墻的方法

    Python 一鍵制作微信好友圖片墻的方法

    這篇文章主要介紹了Python 一鍵制作微信好友圖片墻的方法,有兩種方法,每種方法給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • 在不同系統(tǒng)間遷移Python程序的方法與教程

    在不同系統(tǒng)間遷移Python程序的方法與教程

    本文介紹了幾種將Windows上編寫的Python程序遷移到Linux服務(wù)器上的方法,包括使用虛擬環(huán)境和依賴凍結(jié)、容器化技術(shù)(如Docker)、使用Anaconda環(huán)境以及遠(yuǎn)程桌面連接和配置(作為臨時(shí)方案),通過這些方法,可以有效地解決環(huán)境搭建和依賴安裝問題
    2025-02-02
  • Django的開發(fā)步驟原來是這樣的

    Django的開發(fā)步驟原來是這樣的

    這篇文章主要為大家詳細(xì)介紹了Django的開發(fā)步驟,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • matplotlib交互式數(shù)據(jù)光標(biāo)mpldatacursor的實(shí)現(xiàn)

    matplotlib交互式數(shù)據(jù)光標(biāo)mpldatacursor的實(shí)現(xiàn)

    這篇文章主要介紹了matplotlib交互式數(shù)據(jù)光標(biāo)mpldatacursor的實(shí)現(xiàn) ,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Python調(diào)用系統(tǒng)底層API播放wav文件的方法

    Python調(diào)用系統(tǒng)底層API播放wav文件的方法

    這篇文章主要介紹了Python調(diào)用系統(tǒng)底層API播放wav文件的方法,涉及Python使用pywin32調(diào)用系統(tǒng)底層API讀取與播放wav文件的相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • 9種python web 程序的部署方式小結(jié)

    9種python web 程序的部署方式小結(jié)

    python有很多web 開發(fā)框架,代碼寫完了,部署上線是個(gè)大事,通常來說,web應(yīng)用一般是三層結(jié)構(gòu)web server ---->application -----> DB server
    2014-06-06
  • python編碼總結(jié)(編碼類型、格式、轉(zhuǎn)碼)

    python編碼總結(jié)(編碼類型、格式、轉(zhuǎn)碼)

    這篇文章主要介紹了python編碼操作,包括編碼類型、格式、轉(zhuǎn)碼等,并結(jié)合實(shí)例分析了相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2016-07-07
  • python聚類算法解決方案(rest接口/mpp數(shù)據(jù)庫/json數(shù)據(jù)/下載圖片及數(shù)據(jù))

    python聚類算法解決方案(rest接口/mpp數(shù)據(jù)庫/json數(shù)據(jù)/下載圖片及數(shù)據(jù))

    這篇文章主要介紹了python聚類算法解決方案(rest接口/mpp數(shù)據(jù)庫/json數(shù)據(jù)/下載圖片及數(shù)據(jù)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08

最新評(píng)論