亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中l(wèi)ogging日志模塊代碼調(diào)試過(guò)程詳解

 更新時(shí)間:2023年04月29日 09:12:13   作者:csdn1561168266  
這篇文章主要介紹了Python中l(wèi)ogging日志模塊代碼調(diào)試,今天來(lái)看看如何在代碼中定義日志,并探討日志的權(quán)限,需要的朋友可以參考下

大家好,為了進(jìn)行調(diào)試和錯(cuò)誤跟蹤,人們?cè)谡麄€(gè)代碼庫(kù)中廣泛使用日志,今天來(lái)看看如何在代碼中定義日志,并探討日志的權(quán)限。

一、日志層級(jí)

在開(kāi)始之前,需要注意的是,在日志記錄中存在一個(gè)層次結(jié)構(gòu),稱為日志樹(shù)或日志者層次結(jié)構(gòu)。該層次結(jié)構(gòu)由幾個(gè)級(jí)別組成,每個(gè)級(jí)別代表了日志信息的不同嚴(yán)重程度。最常見(jiàn)的層次是:

CRITICAL #A critical error occurred, the program may not be able to continue running.
ERROR    #An error occurred that should be investigated.
WARNING  #An indication that something unexpected happened or indicative of some problem in the near future.
INFO     #General information about the program's execution.
DEBUG    #Detailed information for debugging purposes.

二、創(chuàng)建模塊

讓我們創(chuàng)建一個(gè)名為set_logging.py的python模塊:

import logging
logger = logging.getLogger()
def set_logger():
  logger.setLevel(logging.INFO)
  handler = logging.StreamHandler()
  handler.setLevel(logger_level)
  formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
  handler.setFormatter(formatter)
  logger.addHandler(handler)

為了明確代碼,我們用getLogger函數(shù)創(chuàng)建一個(gè)日志器實(shí)例,并使用setLevel來(lái)設(shè)置日志級(jí)別(DEBUG、INFO等)。日志器的setLevel方法就像一個(gè)過(guò)濾器,它決定了一條日志信息是否應(yīng)該被處理并發(fā)送給處理程序。例如,如果我們將日志記錄器的級(jí)別設(shè)置為INFO,那么日志記錄器就不會(huì)向處理程序發(fā)送級(jí)別為DEBUG的消息,因?yàn)樗鼈兊膰?yán)重程度低于在日志記錄器上設(shè)置的最低級(jí)別。它只將級(jí)別為INFO或更高的日志消息(即WARNINGERRORCRITICAL)發(fā)送給處理程序進(jìn)行處理。

我們創(chuàng)建一個(gè)StreamHandler,將日志信息發(fā)送到一個(gè)流中,如控制臺(tái)或終端。它被用來(lái)輸出日志信息以達(dá)到調(diào)試的目的。我們還為處理程序設(shè)置了級(jí)別。

我們這樣做是因?yàn)楫?dāng)處理程序收到來(lái)自日志記錄器的消息時(shí),它將把這些消息與它的級(jí)別進(jìn)行比較,并在發(fā)出之前過(guò)濾掉嚴(yán)重程度較低的消息。當(dāng)我們有不同的處理程序時(shí):

?logger.setLevel(logging.INFO)
file_handler = logging.FileHandler()
file_handler.setLevel(logging.ERROR)
console_handler = logging.StreamHandler()
console_handler.setLevel(logging.WARNING)

由于日志記錄器的級(jí)別被設(shè)置為INFO,它只向兩個(gè)處理程序發(fā)送級(jí)別為INFO或更高的日志消息,但每個(gè)處理程序只處理達(dá)到或超過(guò)其指定日志級(jí)別的消息。

回到我們的主要例子,然后我們創(chuàng)建一個(gè)格式化器并將其添加到處理程序中。格式化器指定了日志消息的格式,包括時(shí)間戳、日志記錄器名稱、日志級(jí)別和消息。最后,我們將處理程序添加到日志記錄器中"。

現(xiàn)在在代碼中,需要調(diào)用set_logger,如下所示:

import logging
from set_logging import set_logger
set_logger()
logger = logging.getLogger()
def roman_number(s: str) -> int:
    dic = {"I": 1, "V": 5, "X": 10, "L": 50, "C": 100, "D": 500, "M": 1000}
    res = 0
    pre = None
    for char in s:
        res += dic.get(char)
        if dic.get(pre) and dic.get(pre) < dic.get(char):
            res -= 2 * dic.get(pre)
        pre = char
    logger.info("logging is awesome")
    return res
roman_number("IV")

運(yùn)行這段代碼,結(jié)果如下:

2023-03-04 02:26:57,619 - root - INFO - logging is awesome

三、使用日志的優(yōu)點(diǎn)

  • 級(jí)別。一個(gè)日志記錄器提供了一種方法來(lái)為不同類型的消息設(shè)置不同的日志級(jí)別,如DEBUG、INFO、WARNINGERRORCRITICAL。這使得根據(jù)日志消息的嚴(yán)重程度來(lái)過(guò)濾和確定其優(yōu)先級(jí)變得更加容易。當(dāng)然,打印可以模仿與日志相同的行為,但它需要更多的硬編碼工作,而且不像日志那樣靈活。
  • 性能。打印日志信息可能比使用記錄器慢,特別是在處理大量數(shù)據(jù)或頻繁進(jìn)行記錄的時(shí)候。
  • 可配置性。記錄器提供了一種方法來(lái)配置應(yīng)用程序的日志行為,如日志級(jí)別、日志目的地和日志格式,而無(wú)需修改源代碼。這使得隨著時(shí)間的推移,更容易管理和維護(hù)日志行為。
  • 靈活性。記錄器允許你將日志信息發(fā)送到多個(gè)目的地,如控制臺(tái)、文件或數(shù)據(jù)庫(kù)。這種靈活性使得管理日志和分析它們變得更加容易。

到此這篇關(guān)于Python中l(wèi)ogging日志模塊代碼調(diào)試的文章就介紹到這了,更多相關(guān)Python logging日志模塊內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • flask使用session保存登錄狀態(tài)及攔截未登錄請(qǐng)求代碼

    flask使用session保存登錄狀態(tài)及攔截未登錄請(qǐng)求代碼

    這篇文章主要介紹了flask使用session保存登錄狀態(tài)及攔截未登錄請(qǐng)求代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • Pandas處理時(shí)間序列數(shù)據(jù)操作詳解

    Pandas處理時(shí)間序列數(shù)據(jù)操作詳解

    這篇文章主要介紹了Pandas處理時(shí)間序列數(shù)據(jù)操作詳解,文章首先利用python自帶datetime庫(kù),通過(guò)調(diào)用此庫(kù)可以獲取本地時(shí)間展開(kāi)內(nèi)容說(shuō)明具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-06-06
  • Numpy中np.max的用法及np.maximum區(qū)別

    Numpy中np.max的用法及np.maximum區(qū)別

    這篇文章主要介紹了Numpy中np.max的用法及np.maximum區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • python如何將圖片批量保存至word文檔中

    python如何將圖片批量保存至word文檔中

    這篇文章主要介紹了python如何將圖片批量保存至word文檔中問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • PyTorch基礎(chǔ)之torch.nn.CrossEntropyLoss交叉熵?fù)p失

    PyTorch基礎(chǔ)之torch.nn.CrossEntropyLoss交叉熵?fù)p失

    這篇文章主要介紹了PyTorch基礎(chǔ)之torch.nn.CrossEntropyLoss交叉熵?fù)p失講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • python手寫選擇排序方式(不用sort)

    python手寫選擇排序方式(不用sort)

    這篇文章主要介紹了python手寫選擇排序方式(不用sort),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Python中的字典合并與列表合并技巧

    Python中的字典合并與列表合并技巧

    這篇文章主要介紹了Python中的字典合并與列表合并技巧,下文圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一的的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • IDLE下Python文件編輯和運(yùn)行操作

    IDLE下Python文件編輯和運(yùn)行操作

    這篇文章主要介紹了IDLE下Python文件編輯和運(yùn)行操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • Python協(xié)程原理全面分析

    Python協(xié)程原理全面分析

    協(xié)程(co-routine,又稱微線程、纖程)是一種多方協(xié)同的工作方式。協(xié)程不是進(jìn)程或線程,其執(zhí)行過(guò)程類似于Python函數(shù)調(diào)用,Python的asyncio模塊實(shí)現(xiàn)的異步IO編程框架中,協(xié)程是對(duì)使用async關(guān)鍵字定義的異步函數(shù)的調(diào)用
    2023-02-02
  • Django項(xiàng)目如何正確配置日志(logging)

    Django項(xiàng)目如何正確配置日志(logging)

    本文將教你如何在Django項(xiàng)目中正確配置日志(logging),讓Django生成log日志文件,并在程序運(yùn)行發(fā)生error級(jí)別故障時(shí)通知管理員。
    2021-04-04

最新評(píng)論