python之停止打印日志/重復(fù)打印日志方式
python停止打印日志/重復(fù)打印日志
問題描述
用類實現(xiàn)了一個需求,每次實例化時,會根據(jù)傳入的參數(shù),在不同的日志文件中寫入日志,即要求類的每個實例根據(jù)傳參寫入不同的日志文件。
運行后發(fā)現(xiàn) ,運行到根據(jù)c2配置的實例 時,c2實例的日志出現(xiàn)在了c1的日志文件中,控制臺日志也是重復(fù)的,即使把實例 del 刪除也還是會打印重復(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")
# 控制臺日志
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()問題原因
logging.getLogger( ), 并未傳遞參數(shù), 所以得到的self.logger是RootLogger。
RootLogger是一個python程序內(nèi)全局唯一的,所有Logger對象的父類,對RootLogger的設(shè)定,均會影響到后續(xù)的日志。
解決辦法
方法1
getLogger設(shè)置參數(shù)
logger = logging.getLogger('%s_%d' % (self.course_name, int(time.time())))方法2
類實例銷毀前清空log.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()
passpython程序中斷時,輸出打印日志
在class中添加一個方法
def __del__(self):
? ? ?dbg.info("exit")親測有效?。。?/p>
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python pygorithm模塊用法示例【常見算法測試】
這篇文章主要介紹了Python pygorithm模塊用法,結(jié)合實例形式分析了pygorithm模塊的功能、安裝及針對常見算法的相關(guān)使用操作技巧,需要的朋友可以參考下2018-08-08
Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù)的實現(xiàn)代碼
這篇文章主要介紹了Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12
解決python3 HTMLTestRunner測試報告中文亂碼的問題
今天小編就為大家分享一篇解決python3 HTMLTestRunner測試報告中文亂碼的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12

