Python日志處理模塊logging用法解析
logging模塊是Python內(nèi)置的標(biāo)準(zhǔn)模塊,主要用于輸出運行日志,可以設(shè)置輸出日志的等級、日志保存路徑、日志文件回滾等。
其主要優(yōu)點如下:
1.可以通過設(shè)置不同的日志等級,在release版本中只輸出重要信息,而不必顯示大量的調(diào)試信息;
2.尤其是代碼運行在服務(wù)器上,當(dāng)出現(xiàn)問題時可以通過查看日志進行分析。
logging模塊基本使用:
設(shè)置logger名稱
logger = logging.getLogger(log_name)
設(shè)置log級別
logger.setLevel(logging.info)
創(chuàng)建一個handler,用于寫入日志文件
fh = logging.FileHandler(log_file)
設(shè)置日志級別,默認(rèn)為logging.WARNING
fh.setLevel(logLevel[log_level])
定義handler的輸出格式
formatter = logging.Formatter('%(asctime)s %(name)s [line:%(lineno)d] %(levelname)s %(message)s')
fh.setFormatter(formatter)
添加handler
logger.addHandler(fh)
format
- %(levelno)s: 打印日志級別的數(shù)值
- %(levelname)s: 打印日志級別名稱
- %(pathname)s: 打印當(dāng)前執(zhí)行程序的路徑,其實就是sys.argv[0]
- %(filename)s: 打印當(dāng)前執(zhí)行程序名
- %(funcName)s: 打印日志的當(dāng)前函數(shù)
- %(lineno)d: 打印日志的當(dāng)前行號
- %(asctime)s: 打印日志的時間
- %(thread)d: 打印線程ID
- %(threadName)s: 打印線程名稱
- %(process)d: 打印進程ID
- %(message)s: 打印日志信息
示例代碼如下:
import logging
import datetime
import os
# 定義日志級別字典
logLevelDic={
"info":logging.INFO,
"debug":logging.DEBUG,
"warning":logging.WARNING,
"error":logging.ERROR
}
# 日志保存路徑
logSavePath=os.path.join(os.getcwd(),"logs")
if not os.path.exists(logSavePath):
os.makedirs(logSavePath,exist_ok=True)
# 當(dāng)前時間
curTime=datetime.datetime.now().strftime("%Y%m%d")
# 保存的日志的完整名稱
logFile=os.path.join(logSavePath,curTime+".SADCI.log")
# 日志級別
logLevel="error"
class Logger:
def __init__(self,logFile=logFile,logLevel=logLevelDic["error"]):
self.logFile=logFile
self.logLevel=logLevel
# 設(shè)置logger名稱
self.logger=logging.getLogger()
# 設(shè)置參數(shù)級別
self.logger.setLevel(self.logLevel)
self.formatter=logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
# 判斷handlers是否存在
if not self.logger.handlers:
# 寫入控制臺
consoleStream=logging.StreamHandler()
consoleStream.setLevel(self.logLevel)
consoleStream.setFormatter(self.formatter)
# 寫入文件
fileStream=logging.FileHandler(self.logFile,mode="a")
fileStream.setLevel(self.logLevel)
fileStream.setFormatter(self.formatter)
self.logger.addHandler(consoleStream)
self.logger.addHandler(fileStream)
def MyLogger():
return Logger(logFile=logFile,logLevel=logLevelDic[logLevel]).logger
if __name__ == '__main__':
MyLogger().error("test logg")
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python中l(wèi)azy property的兩種方法小結(jié)
本文介紹了Python中實現(xiàn)延遲屬性lazyproperty的兩種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-01-01
python使用IP歸屬地查詢API追蹤網(wǎng)絡(luò)活動
這篇文章主要為大家介紹了python使用IP歸屬地查詢API追蹤網(wǎng)絡(luò)活動實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09
使用python的pexpect模塊,實現(xiàn)遠(yuǎn)程免密登錄的示例
今天小編就為大家分享一篇使用python的pexpect模塊,實現(xiàn)遠(yuǎn)程免密登錄的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-02-02
python字符串,元組,列表,字典互轉(zhuǎn)代碼實例詳解
這篇文章主要介紹了python字符串,元組,列表,字典互轉(zhuǎn)代碼實例詳解,需要的朋友可以參考下2020-02-02

