Python中的Logging模塊在項(xiàng)目應(yīng)用小結(jié)
在Python編程中,日志記錄(Logging)是一項(xiàng)至關(guān)重要的任務(wù),它幫助我們跟蹤代碼的運(yùn)行狀態(tài)、識(shí)別錯(cuò)誤以及優(yōu)化程序性能。Python標(biāo)準(zhǔn)庫中的logging模塊為我們提供了強(qiáng)大而靈活的日志記錄功能。本文將介紹如何使用logging模塊,并探討其在Python開發(fā)中的實(shí)際應(yīng)用。
一、基本使用
首先,我們需要導(dǎo)入logging模塊,并配置基本的日志記錄器(Logger)。以下是一個(gè)簡單的示例:
python import logging # 配置日志記錄器 logging.basicConfig(level=logging.DEBUG, format='%(asctime)s - %(levelname)s - %(message)s', filename='example.log', filemode='w') # 在代碼中使用日志記錄器 logging.debug('This is a debug message.') logging.info('This is an info message.') logging.warning('This is a warning message.') logging.error('This is an error message.') logging.critical('This is a critical message.')
在這個(gè)示例中,我們首先通過basicConfig方法配置了日志記錄器。level參數(shù)用于設(shè)置日志級(jí)別,這里我們?cè)O(shè)置為DEBUG,意味著所有級(jí)別的日志都會(huì)被記錄。format參數(shù)用于定義日志消息的格式,包括時(shí)間戳、日志級(jí)別和消息內(nèi)容。filename參數(shù)指定了日志文件的名稱,filemode參數(shù)用于設(shè)置文件的打開模式。
接下來,我們?cè)诖a中使用了不同級(jí)別的日志記錄方法,如debug、info、warning、error和critical。這些方法會(huì)根據(jù)配置的日志級(jí)別來決定是否記錄消息。
二、高級(jí)配置
除了基本配置外,logging模塊還支持更高級(jí)的配置選項(xiàng),以滿足復(fù)雜的日志記錄需求。例如,我們可以創(chuàng)建多個(gè)日志記錄器,為每個(gè)記錄器設(shè)置不同的處理器(Handler)和格式化器(Formatter)。
以下是一個(gè)更復(fù)雜的示例,展示了如何創(chuàng)建多個(gè)日志記錄器,并將日志輸出到控制臺(tái)和文件:
python import logging # 創(chuàng)建一個(gè)日志記錄器 logger = logging.getLogger('my_logger') logger.setLevel(logging.DEBUG) # 創(chuàng)建一個(gè)控制臺(tái)處理器,將日志輸出到控制臺(tái) console_handler = logging.StreamHandler() console_handler.setLevel(logging.INFO) # 創(chuàng)建一個(gè)文件處理器,將日志輸出到文件 file_handler = logging.FileHandler('example.log') file_handler.setLevel(logging.DEBUG) # 創(chuàng)建一個(gè)格式化器,定義日志消息的格式 formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') # 將格式化器添加到處理器中 console_handler.setFormatter(formatter) file_handler.setFormatter(formatter) # 將處理器添加到記錄器中 logger.addHandler(console_handler) logger.addHandler(file_handler) # 在代碼中使用日志記錄器 logger.debug('This is a debug message.') logger.info('This is an info message.') logger.warning('This is a warning message.') logger.error('This is an error message.') logger.critical('This is a critical message.')
在這個(gè)示例中,我們首先創(chuàng)建了一個(gè)名為my_logger的日志記錄器,并設(shè)置了日志級(jí)別為DEBUG。然后,我們創(chuàng)建了一個(gè)控制臺(tái)處理器和一個(gè)文件處理器,并分別為它們?cè)O(shè)置了日志級(jí)別和格式化器。最后,我們將這兩個(gè)處理器添加到了記錄器中。這樣,當(dāng)我們使用logger對(duì)象記錄日志時(shí),消息會(huì)同時(shí)輸出到控制臺(tái)和文件中。
三、日志模塊結(jié)構(gòu)
組件名稱 | 對(duì)應(yīng)的類 | 對(duì)應(yīng)描述 |
---|---|---|
日志記錄器 | Logger | 提供了應(yīng)用程序的日志記錄功能 |
處理器 | Handler | 提供日志的一條處理方式 |
過濾器 | Filter | 提供了更細(xì)顆粒的控制工具來決定輸出日志的記錄 |
格式化器 | Formmtter | 提供日志的格式 |
四、項(xiàng)目中應(yīng)用
如下的代碼為django項(xiàng)目中使用日志記錄模塊的示例
import os import logging import sys from django.conf import settings from datetime import datetime os.makedirs(settings.LOGS, exist_ok=True) class Logger: _instance = None def __init__(self): self.format = '%(asctime)s %(thread)d %(threadName)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s' # django中項(xiàng)目的名稱 self.logger = logging.getLogger(settings.PROJECTNAME) self.logger.setLevel(logging.DEBUG) self.add_stream_handle() self.file = os.path.join(settings.LOGS, f'{datetime.now().strftime("%Y%m%d_%H%M%S")}.log') self.add_file_handle(self.file) def add_stream_handle(self): handler = logging.StreamHandler(sys.stdout) handler.setLevel(level=logging.INFO) handler.setFormatter(logging.Formatter(self.format)) self.logger.addHandler(handler) def add_file_handle(self, file): handler = logging.FileHandler(file, encoding="utf-8") handler.setLevel(level=logging.DEBUG) handler.setFormatter(logging.Formatter(self.format)) self.logger.addHandler(handler) @classmethod def get_logger(cls): # 初始化一次,通常__init__.py文件中調(diào)用 if cls._instance is None: cls._instance = Logger().logger return cls._instance Logger.get_logger()
# 其他模塊中使用 import logging from django.conf import settings logger = logging.getLogger(settings.PROJECTNAME) logger.info("INFO") logger.warning("WARNING") logger.error("ERROR")
到此這篇關(guān)于Python中的Logging模塊在項(xiàng)目應(yīng)用小結(jié)的文章就介紹到這了,更多相關(guān)Python Logging模塊內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python讀取并顯示圖片的三種方法(opencv、matplotlib、PIL庫)
這篇文章主要給大家介紹了關(guān)于python讀取并顯示圖片的三種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04高質(zhì)量Python代碼編寫的5個(gè)優(yōu)化技巧
這篇文章主要為大家詳細(xì)介紹了編寫高質(zhì)量Python代碼的5個(gè)優(yōu)化技巧,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11在Python中使用itertools模塊中的組合函數(shù)的教程
這篇文章主要介紹了在Python中使用itertools模塊中的組合函數(shù)的教程,來自IBM官方技術(shù)文檔,需要的朋友可以參考下2015-04-04Pytorch?PyG實(shí)現(xiàn)EdgePool圖分類
這篇文章主要為大家介紹了Pytorch?PyG實(shí)現(xiàn)EdgePool圖分類示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04windows python3安裝Jupyter Notebooks教程
這篇文章主要介紹了windows python3安裝Jupyter Notebooks教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解
這篇文章主要為大家介紹了Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11django+celery+RabbitMQ自定義多個(gè)消息隊(duì)列的實(shí)現(xiàn)
本文主要介紹了django+celery+RabbitMQ自定義多個(gè)消息隊(duì)列的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02