python實(shí)現(xiàn)自定義日志的具體方法
1、導(dǎo)入logging模塊:
import logging
2、創(chuàng)建日志收集器:
logger = logging.getLogger(“日志收集器的name”)
3、設(shè)置日志收集器的日志級別:
logger.setLevel(logging.INFO) #設(shè)置收集器的級別為INFO。
4、給日志收集器創(chuàng)建輸出渠道,根據(jù)第一部分的內(nèi)容知:日志輸出渠道包含控制臺輸出和文件輸出。
5、設(shè)置日志輸出的內(nèi)容格式。
# 設(shè)置日志的輸出格式 fmt = "%(asctime)s %(name)s %(levelname)s %(filename)s-%(lineno)d:%(message)s" formatter = logging.Formatter(fmt)
6、將設(shè)置的日志格式綁定到創(chuàng)建的輸出渠道中,即將日志格式與輸出渠道關(guān)聯(lián)起來。
7、將設(shè)置好的輸出渠道,添加到日志收集器。
實(shí)例擴(kuò)展:
import os
import time
import logging
#返回一個logger實(shí)例,如果沒有指定name,返回root logger。
# 只要name相同,返回的logger實(shí)例都是同一個而且只有一個,即name和logger實(shí)例是一一對應(yīng)的。
# 這意味著,無需把logger實(shí)例在各個模塊中傳遞。只要知道name,就能得到同一個logger實(shí)例。
logger = logging.getLogger('mylogger')
# 設(shè)置總?cè)罩炯墑e, 也可以給不同的handler設(shè)置不同的日志級別
#設(shè)置logger的level, level有以下幾個級別:
# 級別高低順序:NOTSET < DEBUG < INFO < WARNING < ERROR < CRITICAL
# 如果把looger的級別設(shè)置為INFO, 那么小于INFO級別的日志都不輸出, 大于等于INFO級別的日志都輸出
logger.setLevel(logging.DEBUG)
# 控制臺日志和日志文件使用同一個formatter,formatter用于描述日志的格式
formatter = logging.Formatter(
'%(asctime)s - %(filename)s[line:%(lineno)d] - <%(threadName)s %(thread)d>' +
'- <Process %(process)d> - %(levelname)s: %(message)s'
)
# asctime:日志產(chǎn)生的時間;filename:產(chǎn)生日志的腳本文件名;lineno:該腳本文件哪一行代碼產(chǎn)生了日志
# threadName: 當(dāng)前線程名;thread: 當(dāng)前進(jìn)程名;Process進(jìn)程同thread線程
# levelname: logger的級別;meesage: 具體的日志信息
# 創(chuàng)建Handler, 輸出日志到控制臺和文件
# 日志文件FileHandler
basedir = os.path.abspath(".") #返回腳本所在的絕對路徑
log_dir = os.path.join(basedir, 'logs') # 日志文件所在目錄,即‘腳本路徑/logs'
if not os.path.isdir(log_dir):
os.mkdir(log_dir)
filename = time.strftime('%Y-%m-%d-%H-%M-%S', time.localtime(time.time())) + '.log' # 日志文件名,以當(dāng)前時間命名
file_handler = logging.FileHandler(os.path.join(log_dir, filename)) # 創(chuàng)建日志文件handler
file_handler.setFormatter(formatter) # 設(shè)置Formatter
file_handler.setLevel(logging.INFO) # 單獨(dú)設(shè)置日志文件的日志級別
# 控制臺日志StreamHandler
stream_handler = logging.StreamHandler()
stream_handler.setFormatter(formatter)
# stream_handler.setLevel(logging.INFO) # 單獨(dú)設(shè)置控制臺日志的日志級別,注釋掉則使用總?cè)罩炯墑e
# 將handler添加到logger中
logger.addHandler(file_handler)
logger.addHandler(stream_handler)
到此這篇關(guān)于python實(shí)現(xiàn)自定義日志的具體方法的文章就介紹到這了,更多相關(guān)python自定義日志如何實(shí)現(xiàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python 第三方日志框架loguru使用
- python和websocket構(gòu)建實(shí)時日志跟蹤器的步驟
- 解決python logging遇到的坑 日志重復(fù)打印問題
- python 實(shí)現(xiàn)多進(jìn)程日志輪轉(zhuǎn)ConcurrentLogHandler
- python 實(shí)現(xiàn)logging動態(tài)變更輸出日志文件名
- python (logging) 日志按日期、大小回滾的操作
- 詳解python日志輸出使用配置文件格式
- python基于pexpect庫自動獲取日志信息
- Python日志打印里logging.getLogger源碼分析詳解
- python subprocess pipe 實(shí)時輸出日志的操作
- Python中l(wèi)ogging日志的四個等級和使用
- 如何在Python項(xiàng)目中引入日志
相關(guān)文章
python命令行運(yùn)行報(bào)錯ModuleNotFoundError:No module named‘X
這篇文章主要介紹了python命令行運(yùn)行報(bào)錯ModuleNotFoundError:No module named‘XXX‘找不到自定義模塊問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
python統(tǒng)計(jì)列表中元素出現(xiàn)次數(shù)的三種方法
這篇文章主要介紹了python統(tǒng)計(jì)列表中元素出現(xiàn)次數(shù)的三種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08
pyecharts繪制時間輪播圖柱形圖+餅圖+玫瑰圖+折線圖
這篇文章主要介紹了pyecharts繪制時間輪播圖柱形圖+餅圖+玫瑰圖+折線圖,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-06-06
Python中將圖像轉(zhuǎn)換為PDF的方法實(shí)現(xiàn)
本文主要介紹了Python中將圖像轉(zhuǎn)換為PDF的方法實(shí)現(xiàn),主要使用img2pdf和PyPDF2軟件包,具有一定的參考價值,感興趣的可以了解一下2023-08-08
python?tornado協(xié)程調(diào)度原理示例解析
這篇文章主要為大家介紹了python?tornado協(xié)程調(diào)度原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
解決python cv2.imread 讀取中文路徑的圖片返回為None的問題
這篇文章主要介紹了解決python cv2.imread 讀取中文路徑的圖片返回為None的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
Selenium定時刷新網(wǎng)頁的實(shí)現(xiàn)代碼
這篇文章主要介紹了Selenium定時刷新網(wǎng)頁的實(shí)現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10
深入解析Python中函數(shù)的參數(shù)與作用域
這篇文章主要介紹了Python中函數(shù)的參數(shù)與作用域,是Python入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2016-03-03

