国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python logging 重復寫日志問題解決辦法詳解

瀏覽:63日期:2022-07-15 10:21:51

python logging 重復寫日志問題

用Python的logging模塊記錄日志時,遇到了重復記錄日志的問題,第一條記錄寫一次,第二條記錄寫兩次,第三條記錄寫三次。。。很頭疼,這樣記日志可不行。網上搜索到了原因與解決方案:

原因:沒有移除handler 解決:在日志記錄完之后removeHandler

修改前示例代碼:

import loggingdef log(message): logger = logging.getLogger(’testlog’) streamhandler = logging.StreamHandler() streamhandler.setLevel(logging.ERROR) formatter = logging.Formatter(’%(asctime)s - %(levelname)s - %(name)s - %(message)s’) streamhandler.setFormatter(formatter) logger.addHandler(streamhandler) logger.error(message)if __name__ == ’__main__’: log(’hi’) log(’hi too’) log(’hi three’)

修改前輸出結果:

2016-07-08 09:17:29,740 - ERROR - testlog - hi 2016-07-08 09:17:29,740 - ERROR - testlog - hi too 2016-07-08 09:17:29,740 - ERROR - testlog - hi too 2016-07-08 09:17:29,740 - ERROR - testlog - hi three 2016-07-08 09:17:29,740 - ERROR - testlog - hi three 2016-07-08 09:17:29,740 - ERROR - testlog - hi three

修改后示例代碼:

import loggingdef log(message): logger = logging.getLogger(’testlog’) streamhandler = logging.StreamHandler() streamhandler.setLevel(logging.ERROR) formatter = logging.Formatter(’%(asctime)s - %(levelname)s - %(name)s - %(message)s’) streamhandler.setFormatter(formatter) logger.addHandler(streamhandler) logger.error(message) # 添加下面一句,在記錄日志之后移除句柄 logger.removeHandler(streamhandler)if __name__ == ’__main__’: log(’hi’) log(’hi too’) log(’hi three’)

修改后輸出結果:

2016-07-08 09:32:28,206 - ERROR - testlog - hi 2016-07-08 09:32:28,206 - ERROR - testlog - hi too 2016-07-08 09:32:28,206 - ERROR - testlog - hi three

深度解析:

Google之后,大概搞明白了,就是你第二次調用log的時候,根據getLogger(name)里的name獲取同一個logger,而這個logger里已經有了第一次你添加的handler,第二次調用又添加了一個handler,所以,這個logger里有了兩個同樣的handler,以此類推,調用幾次就會有幾個handler。。

所以這里有以下幾個解決辦法:

每次創建不同name的logger,每次都是新logger,不會有添加多個handler的問題。(ps:這個辦法太笨,不過我之前就是這么干的。。) 像上面一樣每次記錄完日志之后,調用removeHandler()把這個logger里的handler移除掉。在log方法里做判斷,如果這個logger已有handler,則不再添加handler。 與方法2一樣,不過把用pop把logger的handler列表中的handler移除。

下面是方法3與方法4的代碼示例:

方法3:

import loggingdef log(message): logger = logging.getLogger(’testlog’) # 這里進行判斷,如果logger.handlers列表為空,則添加,否則,直接去寫日志 if not logger.handlers: streamhandler = logging.StreamHandler() streamhandler.setLevel(logging.ERROR) formatter = logging.Formatter(’%(asctime)s - %(levelname)s - %(name)s - %(message)s’) streamhandler.setFormatter(formatter) logger.addHandler(streamhandler) logger.error(message)if __name__ == ’__main__’: log(’hi’) log(’hi too’) log(’hi three’)

方法4:

import loggingdef log(message): logger = logging.getLogger(’testlog’) streamhandler = logging.StreamHandler() streamhandler.setLevel(logging.ERROR) formatter = logging.Formatter(’%(asctime)s - %(levelname)s - %(name)s - %(message)s’) streamhandler.setFormatter(formatter) logger.addHandler(streamhandler) logger.error(message) # 用pop方法把logger.handlers列表中的handler移除,注意如果你add了多個handler,這里需多次pop,或者可以直接為handlers列表賦空值 logger.handlers.pop() # logger.handler = []if __name__ == ’__main__’: log(’hi’) log(’hi too’) log(’hi three’)

這幾種方法都親試可行,個人覺得方法3判斷更加優雅,你覺得呢?

到此這篇關于python logging 重復寫日志問題j解決辦法詳解的文章就介紹到這了,更多相關python logging 重復寫日志問題內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 一区二三国产 | 美女张开腿双腿让男人桶 | 成人久久久观看免费毛片 | 一级做a爰片性色毛片小说 一级做a爰片性色毛片中国 | 免费人欧美成又黄又爽的视频 | 国产成人免费网站 | 亚洲天堂精品在线观看 | 久久成人性色生活片 | 精品国产免费人成在线观看 | 欧美一区二区aa大片 | 国产成人精品一区二区免费视频 | 男人天堂怡红院 | 中文字幕在线无限2021 | 国产国语一级毛片全部 | 国产成人精品s8p视频 | 粉嫩jk制服美女啪啪 | 欧美性猛交xxxxbbb | 国产精品观看 | 久久亚洲国产 | 最新怡红院全部视频在线 | 一级片免费在线播放 | 欧美国产日韩一区二区三区 | 五月天激激婷婷大综合蜜芽 | 国产第九页| 日本a级毛片免费视频播放 日本a级三级三级三级久久 | 久久精品无遮挡一级毛片 | 亚洲欧美精品中文字幕 | 欧美成人一级毛片 | 美国美女一级毛片免费全 | 久久久久久久久久久福利观看 | 一级做a爰片久久毛片免费看 | 国产精品18久久久久久vr | 手机免费在线看毛片 | 欧美成人久久一级c片免费 欧美成人看片黄a免费 | 视频一区亚洲 | 最新色网址 | 看色网站 | 欧美成人久久 | 色综合久久91 | 成人手机看片 | 亚洲欧美一区二区久久 |