這篇文章主要介紹“Python中l(wèi)ogging日志模塊代碼如何調(diào)試”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“Python中l(wèi)ogging日志模塊代碼如何調(diào)試”文章能幫助大家解決問題。
成都創(chuàng)新互聯(lián)是專業(yè)的祥云網(wǎng)站建設(shè)公司,祥云接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行祥云網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
在開始之前,需要注意的是,在日志記錄中存在一個(gè)層次結(jié)構(gòu),稱為日志樹或日志者層次結(jié)構(gòu)。該層次結(jié)構(gòu)由幾個(gè)級(jí)別組成,每個(gè)級(jí)別代表了日志信息的不同嚴(yá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)建一個(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
來設(shè)置日志級(jí)別(DEBUG
、INFO
等)。日志器的setLevel
方法就像一個(gè)過濾器,它決定了一條日志信息是否應(yīng)該被處理并發(fā)送給處理程序。例如,如果我們將日志記錄器的級(jí)別設(shè)置為INFO
,那么日志記錄器就不會(huì)向處理程序發(fā)送級(jí)別為DEBUG
的消息,因?yàn)樗鼈兊膰?yán)重程度低于在日志記錄器上設(shè)置的最低級(jí)別。它只將級(jí)別為INFO
或更高的日志消息(即WARNING
、ERROR
或CRITICAL
)發(fā)送給處理程序進(jìn)行處理。
我們創(chuàng)建一個(gè)StreamHandler
,將日志信息發(fā)送到一個(gè)流中,如控制臺(tái)或終端。它被用來輸出日志信息以達(dá)到調(diào)試的目的。我們還為處理程序設(shè)置了級(jí)別。
我們這樣做是因?yàn)楫?dāng)處理程序收到來自日志記錄器的消息時(shí),它將把這些消息與它的級(jí)別進(jìn)行比較,并在發(fā)出之前過濾掉嚴(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á)到或超過其指定日志級(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
級(jí)別。一個(gè)日志記錄器提供了一種方法來為不同類型的消息設(shè)置不同的日志級(jí)別,如DEBUG
、INFO
、WARNING
、ERROR
和CRITICAL
。這使得根據(jù)日志消息的嚴(yán)重程度來過濾和確定其優(yōu)先級(jí)變得更加容易。當(dāng)然,打印可以模仿與日志相同的行為,但它需要更多的硬編碼工作,而且不像日志那樣靈活。
性能。打印日志信息可能比使用記錄器慢,特別是在處理大量數(shù)據(jù)或頻繁進(jìn)行記錄的時(shí)候。
可配置性。記錄器提供了一種方法來配置應(yīng)用程序的日志行為,如日志級(jí)別、日志目的地和日志格式,而無需修改源代碼。這使得隨著時(shí)間的推移,更容易管理和維護(hù)日志行為。
靈活性。記錄器允許你將日志信息發(fā)送到多個(gè)目的地,如控制臺(tái)、文件或數(shù)據(jù)庫。這種靈活性使得管理日志和分析它們變得更加容易。
關(guān)于“Python中l(wèi)ogging日志模塊代碼如何調(diào)試”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。
分享標(biāo)題:Python中l(wèi)ogging日志模塊代碼如何調(diào)試
網(wǎng)頁URL:http://sd-ha.com/article30/popcso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、面包屑導(dǎo)航、用戶體驗(yàn)、網(wǎng)站制作、移動(dòng)網(wǎng)站建設(shè)、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)