python之停止打印日志/重復(fù)打印日志方式
python停止打印日志/重復(fù)打印日志
問(wèn)題描述
用類實(shí)現(xiàn)了一個(gè)需求,每次實(shí)例化時(shí),會(huì)根據(jù)傳入的參數(shù),在不同的日志文件中寫(xiě)入日志,即要求類的每個(gè)實(shí)例根據(jù)傳參寫(xiě)入不同的日志文件。
運(yùn)行后發(fā)現(xiàn) ,運(yùn)行到根據(jù)c2配置的實(shí)例 時(shí),c2實(shí)例的日志出現(xiàn)在了c1的日志文件中,控制臺(tái)日志也是重復(fù)的,即使把實(shí)例 del 刪除也還是會(huì)打印重復(fù)日志。
主要代碼如下:
class KKK def __init__(self, log_name, base_path) self.log_name= log_name self.base_path = base_path def start(): .... pass def getLogger(self): # logger = logging.getLogger('%s_%d' % (self.log_name, int(time.time()))) logger = logging.getLogger() logger.setLevel(logging.DEBUG) formatter = logging.Formatter("%(asctime)s|%(lineno)04d|%(levelname)-8s|%(message)s") # 控制臺(tái)日志 StreamHandler = logging.StreamHandler() StreamHandler.setFormatter(formatter) StreamHandler.setLevel(logging.INFO) # 較詳細(xì)的日志 FileHandler = logging.FileHandler(filename=os.path.join(self.base_path, '%s.log' % self.log_name), mode='a', encoding='utf8') FileHandler.setFormatter(formatter) FileHandler.setLevel(logging.DEBUG) logger.addHandler(StreamHandler) logger.addHandler(FileHandler) return logger if __name__ == '__main__': c1 = {...} c2 = {...} for cc in [c1, c2]: kkk = KKK(**cc) kkk.start()
問(wèn)題原因
logging.getLogger( ), 并未傳遞參數(shù), 所以得到的self.logger是RootLogger。
RootLogger是一個(gè)python程序內(nèi)全局唯一的,所有Logger對(duì)象的父類,對(duì)RootLogger的設(shè)定,均會(huì)影響到后續(xù)的日志。
解決辦法
方法1
getLogger設(shè)置參數(shù)
logger = logging.getLogger('%s_%d' % (self.course_name, int(time.time())))
方法2
類實(shí)例銷毀前清空l(shuí)og.handlers
def __del__(self): self.stopLogger() pass def stopLogger(self): # for fh in self.logger.handlers: # print(fh.get_name, '+++++') # if isinstance(fh, logging.FileHandler): # print('close handler') # fh.close() self.logger.warning('關(guān)閉日志, %s , %s' % (self.course_name, self.logger.name)) self.logger.handlers.clear() pass
python程序中斷時(shí),輸出打印日志
在class中添加一個(gè)方法
def __del__(self): ? ? ?dbg.info("exit")
親測(cè)有效?。?!
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python實(shí)現(xiàn)多進(jìn)程通信實(shí)例分析
這篇文章主要介紹了python實(shí)現(xiàn)多進(jìn)程通信實(shí)例分析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09Python中10個(gè)常用的內(nèi)置函數(shù)詳解
這篇文章主要為大家介紹了Python常用的內(nèi)置函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-12-12Python pygorithm模塊用法示例【常見(jiàn)算法測(cè)試】
這篇文章主要介紹了Python pygorithm模塊用法,結(jié)合實(shí)例形式分析了pygorithm模塊的功能、安裝及針對(duì)常見(jiàn)算法的相關(guān)使用操作技巧,需要的朋友可以參考下2018-08-08Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù)的實(shí)現(xiàn)代碼
這篇文章主要介紹了Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Python Matplotlib簡(jiǎn)易教程(小白教程)
這篇文章主要介紹了Python Matplotlib簡(jiǎn)易教程(小白教程),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07解決python3 HTMLTestRunner測(cè)試報(bào)告中文亂碼的問(wèn)題
今天小編就為大家分享一篇解決python3 HTMLTestRunner測(cè)試報(bào)告中文亂碼的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12Python+OpenCV進(jìn)行人臉面部表情識(shí)別
這篇文章主要介紹了通過(guò)Python OpenCV實(shí)現(xiàn)對(duì)人臉面部表情識(shí)別,判斷人是否為笑臉,文中的示例代碼非常詳細(xì),需要的朋友可以參考一下2021-12-12