亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python之停止打印日志/重復(fù)打印日志方式

 更新時間:2023年09月13日 14:47:14   作者:weixin_41956627  
這篇文章主要介紹了python停止打印日志/重復(fù)打印日志方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

python停止打印日志/重復(fù)打印日志

問題描述

用類實(shí)現(xiàn)了一個需求,每次實(shí)例化時,會根據(jù)傳入的參數(shù),在不同的日志文件中寫入日志,即要求類的每個實(shí)例根據(jù)傳參寫入不同的日志文件。

運(yùn)行后發(fā)現(xiàn) ,運(yùn)行到根據(jù)c2配置的實(shí)例 時,c2實(shí)例的日志出現(xiàn)在了c1的日志文件中,控制臺日志也是重復(fù)的,即使把實(shí)例 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

類實(shí)例銷毀前清空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()
        pass

python程序中斷時,輸出打印日志

在class中添加一個方法

def __del__(self):
? ? ?dbg.info("exit")

親測有效?。?!

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python實(shí)現(xiàn)多進(jìn)程通信實(shí)例分析

    python實(shí)現(xiàn)多進(jìn)程通信實(shí)例分析

    這篇文章主要介紹了python實(shí)現(xiàn)多進(jìn)程通信實(shí)例分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Python中類和對象的綁定及非綁定方法詳解

    Python中類和對象的綁定及非綁定方法詳解

    類中定義的方法大致可以分為兩類:綁定方法和非綁定方法。其中綁定方法又可以分為綁定到對象的方法和綁定到類的方法。本文就來聊聊類和對象的綁定及非綁定方法吧
    2023-03-03
  • Python中10個常用的內(nèi)置函數(shù)詳解

    Python中10個常用的內(nèi)置函數(shù)詳解

    這篇文章主要為大家介紹了Python常用的內(nèi)置函數(shù),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Python pygorithm模塊用法示例【常見算法測試】

    Python pygorithm模塊用法示例【常見算法測試】

    這篇文章主要介紹了Python pygorithm模塊用法,結(jié)合實(shí)例形式分析了pygorithm模塊的功能、安裝及針對常見算法的相關(guān)使用操作技巧,需要的朋友可以參考下
    2018-08-08
  • Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù)的實(shí)現(xiàn)代碼

    Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù)的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Python 按比例獲取樣本數(shù)據(jù)或執(zhí)行任務(wù),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • Python Matplotlib簡易教程(小白教程)

    Python Matplotlib簡易教程(小白教程)

    這篇文章主要介紹了Python Matplotlib簡易教程(小白教程),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Python 一鍵制作微信好友圖片墻的方法

    Python 一鍵制作微信好友圖片墻的方法

    這篇文章主要介紹了Python 一鍵制作微信好友圖片墻的方法,有兩種方法,每種方法給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • 解決python3 HTMLTestRunner測試報告中文亂碼的問題

    解決python3 HTMLTestRunner測試報告中文亂碼的問題

    今天小編就為大家分享一篇解決python3 HTMLTestRunner測試報告中文亂碼的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • 跟老齊學(xué)Python之有容乃大的list(3)

    跟老齊學(xué)Python之有容乃大的list(3)

    現(xiàn)在是講lis的第三章了。俗話說,事不過三,不知道在開頭,我也不知道這一講是不是能夠把基礎(chǔ)的list知識講完呢。哈哈。其實(shí)如果真正寫文章,會在寫完之后把這句話刪掉的。而我則是完全像跟看官聊天一樣,就不刪除了。
    2014-09-09
  • Python+OpenCV進(jìn)行人臉面部表情識別

    Python+OpenCV進(jìn)行人臉面部表情識別

    這篇文章主要介紹了通過Python OpenCV實(shí)現(xiàn)對人臉面部表情識別,判斷人是否為笑臉,文中的示例代碼非常詳細(xì),需要的朋友可以參考一下
    2021-12-12

最新評論