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

Python中的Logging模塊在項(xiàng)目應(yīng)用小結(jié)

 更新時(shí)間:2024年04月22日 09:22:10   作者:平時(shí)不搬磚  
Python標(biāo)準(zhǔn)庫中的logging模塊為我們提供了強(qiáng)大而靈活的日志記錄功能,本文將介紹如何使用logging模塊,并探討其在Python開發(fā)中的實(shí)際應(yīng)用,感興趣的朋友一起看看吧

在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庫)

    python讀取并顯示圖片的三種方法(opencv、matplotlib、PIL庫)

    這篇文章主要給大家介紹了關(guān)于python讀取并顯示圖片的三種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • python 數(shù)據(jù)加密代碼

    python 數(shù)據(jù)加密代碼

    使用Python來做數(shù)據(jù)加密同樣簡單,可以使用hashlib或者h(yuǎn)mac模塊來做數(shù)據(jù)加密
    2008-12-12
  • 一文帶你重溫一下Python的對(duì)象模型

    一文帶你重溫一下Python的對(duì)象模型

    在面向?qū)ο蟮睦碚撝校袃蓚€(gè)核心的概念:類和實(shí)例。在?Python?里面,類和實(shí)例都是對(duì)象,也就是所謂的類對(duì)象和實(shí)例對(duì)象。本文主要來大家重溫一下Python對(duì)象模型的相關(guān)知識(shí),感興趣的可以了解一下
    2023-04-04
  • wxPython色環(huán)電阻計(jì)算器

    wxPython色環(huán)電阻計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了wxPython色環(huán)電阻計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 高質(zhì)量Python代碼編寫的5個(gè)優(yōu)化技巧

    高質(zhì)量Python代碼編寫的5個(gè)優(yōu)化技巧

    這篇文章主要為大家詳細(xì)介紹了編寫高質(zhì)量Python代碼的5個(gè)優(yōu)化技巧,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 在Python中使用itertools模塊中的組合函數(shù)的教程

    在Python中使用itertools模塊中的組合函數(shù)的教程

    這篇文章主要介紹了在Python中使用itertools模塊中的組合函數(shù)的教程,來自IBM官方技術(shù)文檔,需要的朋友可以參考下
    2015-04-04
  • Pytorch?PyG實(shí)現(xiàn)EdgePool圖分類

    Pytorch?PyG實(shí)現(xiàn)EdgePool圖分類

    這篇文章主要為大家介紹了Pytorch?PyG實(shí)現(xiàn)EdgePool圖分類示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • windows python3安裝Jupyter Notebooks教程

    windows python3安裝Jupyter Notebooks教程

    這篇文章主要介紹了windows python3安裝Jupyter Notebooks教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解

    Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解

    這篇文章主要為大家介紹了Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • django+celery+RabbitMQ自定義多個(gè)消息隊(duì)列的實(shí)現(xiàn)

    django+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

最新評(píng)論