日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Python logging模塊原理解析及應用

瀏覽:204日期:2022-07-14 10:47:54

一、logging日志模塊等級

常見log級別從高到低:

CRITICAL 》ERROR 》WARNING 》INFO 》DEBUG,默認等級為WARNING,即>=WARNING級別的log才輸出。

日志等級(level) 描述 CRITICAL 當發生嚴重錯誤,導致應用程序不能繼續運行時記錄的信息 ERROR 由于一個更嚴重的問題導致某些功能不能正常運行時記錄的信息 WARNING 當某些不期望的事情發生時記錄的信息(如,磁盤可用空間較低),但是此時應用程序還是正常運行的 INFO 信息詳細程度僅次于DEBUG,通常只記錄關鍵節點信息,用于確認一切都是按照我們預期的那樣進行工作 DEBUG 最詳細的日志信息,典型應用場景是 問題診斷

二、logging模塊的使用方式介紹

logging模塊提供了兩種記錄日志的方式:

第一種方式是使用logging提供的模塊級別的函數 第二種方式是使用Logging日志系統的四大組件

其實,logging所提供的模塊級別的日志記錄函數也是對logging日志系統相關類的封裝而已。

(1)logging模塊定義的模塊級別的常用函數

函數 說明 logging.debug(msg, *args, **kwargs) 創建一條嚴重級別為DEBUG的日志記錄 logging.info(msg, *args, **kwargs) 創建一條嚴重級別為INFO的日志記錄 logging.warning(msg, *args, **kwargs) 創建一條嚴重級別為WARNING的日志記錄 logging.error(msg, *args, **kwargs) 創建一條嚴重級別為ERROR的日志記錄 logging.critical(msg, *args, **kwargs) 創建一條嚴重級別為CRITICAL的日志記錄 logging.log(level, *args, **kwargs) 創建一條嚴重級別為level的日志記錄 logging.basicConfig(**kwargs) 對root logger進行一次性配置

其中logging.basicConfig(**kwargs)函數用于指定“要記錄的日志級別”、“日志格式”、“日志輸出位置”、“日志文件的打開模式”等信息,其他幾個都是用于記錄各個級別日志的函數。

(2)logging模塊的四大組件

組件 說明 loggers 提供應用程序代碼直接使用的接口 handlers 用于將日志記錄發送到指定的目的位置 filters 提供更細粒度的日志過濾功能,用于決定哪些日志記錄將會被輸出(其它的日志記錄將會被忽略) formatters 用于控制日志信息的最終輸出格式

三、自定義Logger模塊類

# testLog1.pyimport loggingimport timeclass Logger(): def __init__(self, logger, level=logging.DEBUG): ’’’ : 自定義Logger模塊類 : logger: logger名 : level: 日志級別 ’’’ # 創建一個logger self.logger = logging.getLogger(logger) self.logger.setLevel(level) # 定義handler的輸出格式 curr_time = time.strftime('%Y-%m-%d') self.LogFileName = ’log’ + curr_time + ’.txt’ fmt = logging.Formatter(’%(asctime)s - %(filename)s:[%(lineno)s] - [%(levelname)s] - %(message)s’) # asctime: 日志事件發生的時間 # filename: 源文件的名稱部分,包含文件后綴 # lineno: 調用日志記錄函數的源代碼所在的行號 # evelname: 該日志記錄的文字形式的日志級別 # message: 日志記錄的文本內容 # 創建一個handler, 用于寫入日志文件 fh = logging.FileHandler(self.LogFileName) fh.setLevel(logging.DEBUG) fh.setFormatter(fmt) # 再創建一個handler,用于輸出到控制臺 ch = logging.StreamHandler() ch.setLevel(logging.DEBUG) ch.setFormatter(fmt) # 給logger添加handler self.logger.addHandler(fh) self.logger.addHandler(ch) # level優先級 # logger.setLevel > handler.setLevel > logging.basicConfigif __name__ == '__main__': log = Logger(__name__, level=logging.DEBUG) log.logger.debug(’debug’) log.logger.log(logging.DEBUG, ’debug’)# 執行testLog1.py,則控制臺輸出如下:2020-08-03 20:36:47,104 - testLog1.py:[117] - [DEBUG] - debug2020-08-03 20:36:47,104 - testLog1.py:[118] - [DEBUG] - debug# 日志文件記錄如下:2020-08-03 20:36:15,982 - testLog1.py:[117] - [DEBUG] - debug2020-08-03 20:36:15,982 - testLog1.py:[118] - [DEBUG] - debug

# testLog2.pyfrom testLog1 import Loggerimport tracebacklog = Logger(__name__)def func(): try: assert 1==2 except Exception: log.logger.info(’測試失敗,輸出信息如下:{}’.format(traceback.format_exc()))# traceback.format_exc() 會返回異常信息的字符串if __name__ == '__main__': func()# 執行testLog2.py,則控制臺輸出如下:2020-08-03 20:43:44,907 - testLog2.py:[11] - [INFO] - 測試失敗,輸出信息如下:Traceback (most recent call last): File 'E:/imooc/testLog.py', line 9, in func assert 1==2AssertionError# 日志文件記錄如下:2020-08-03 20:43:44,907 - testLog2.py:[11] - [INFO] - 測試失敗,輸出信息如下:Traceback (most recent call last): File 'E:/imooc/testLog.py', line 9, in func assert 1==2AssertionError

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品porn| 日韩精品成人| 97精品国产福利一区二区三区| 欧美日韩 国产精品| 日本成人在线视频网站| 日韩**一区毛片| 91精品福利观看| 国产精品porn| 国产suv精品一区| 成人日韩在线观看| 婷婷六月综合| 99国产精品自拍| 美国三级日本三级久久99| 中文字幕一区二区三区日韩精品| 亚洲免费播放| 中文字幕日韩欧美精品高清在线| 亚洲日产国产精品| 欧美日韩一区二区高清| 久久天堂影院| 一区二区三区四区在线看| 最新日韩欧美| 欧美日本二区| 日韩电影二区| 首页国产欧美日韩丝袜| 国产欧美日韩一级| 日韩成人精品一区| 欧美在线资源| 日本在线观看不卡视频| 美女精品久久| 日韩网站中文字幕| 丝袜亚洲另类欧美| 国产欧美日韩一区二区三区四区| 成人在线免费观看91| 久久国产直播| 蜜桃视频免费观看一区| 麻豆精品新av中文字幕| 日韩精品久久久久久久电影99爱 | 国产日本亚洲| 国产99在线| 亚洲一区二区网站| 国产欧美日韩影院| 91精品一区二区三区综合在线爱| 免费观看在线综合| 国产精品久久久一区二区| 麻豆理论在线观看| 亚洲欧美日本国产专区一区| 久久国产欧美日韩精品| 在线天堂中文资源最新版| 视频一区欧美精品| 另类综合日韩欧美亚洲| 99国产一区| 国产成人精品999在线观看| 久久福利一区| 精品国产亚洲一区二区三区大结局 | 一区二区91| 手机在线电影一区| 99re国产精品| 日韩综合一区| 日韩欧美中文字幕一区二区三区| 中国字幕a在线看韩国电影| 中文字幕亚洲精品乱码| 亚洲精品永久免费视频| 蜜桃一区二区三区在线观看| 国产成人免费av一区二区午夜| 国产亚洲永久域名| 风间由美中文字幕在线看视频国产欧美| 妖精视频成人观看www| 久久免费精品| 婷婷综合国产| 激情五月综合| 成人精品高清在线视频| 蜜桃视频一区二区三区| 精品亚洲美女网站| 国产精品调教| 蜜桃久久久久久| 欧美亚洲国产激情| 麻豆视频一区二区| 亚洲精品无播放器在线播放| 久久国产日本精品| 精品一区二区三区亚洲| 亚洲精品综合| 欧美成人综合| bbw在线视频| 欧美国产中文高清| 日韩国产一二三区| 亚洲资源av| 亚洲一区资源| 国产精品videossex| 综合五月婷婷| 91久久午夜| 久久激情婷婷| 国产精品伦理久久久久久| 91精品国产自产精品男人的天堂 | 日本午夜精品视频在线观看| 99国产精品| 免费av一区二区三区四区| 国内精品麻豆美女在线播放视频| 日韩和欧美一区二区三区| 1024精品久久久久久久久| 高清精品久久| 欧美激情视频一区二区三区免费| 日本成人在线不卡视频| 亚洲开心激情| 石原莉奈在线亚洲二区| 国产亚洲激情| 国产视频一区在线观看一区免费| 激情综合激情| 色天使综合视频| 日韩在线高清| 精品免费视频| 麻豆91小视频| 久久亚洲道色| 麻豆一区二区99久久久久| 91综合久久爱com| 日本不卡视频在线观看| 最近国产精品视频| 在线观看视频免费一区二区三区| 久久亚洲国产精品一区二区| 在线一区视频| 日韩在线观看一区二区| 香蕉视频成人在线观看| 午夜在线精品偷拍| 香蕉久久夜色精品国产| 久久香蕉精品| 蜜桃久久精品一区二区| 在线免费观看亚洲| 日韩中文字幕麻豆| 四虎在线精品| 日精品一区二区三区| 亚洲天堂日韩在线| 亚洲精品观看| 国产日韩欧美在线播放不卡| 国产精品毛片久久久| 狂野欧美性猛交xxxx| 国产成人黄色| 99久久亚洲精品蜜臀| 亚洲成人免费| 久热re这里精品视频在线6| 亚洲一区二区三区在线免费| 日韩精品视频在线看| 国产欧美日韩| 韩日一区二区| 日韩精品电影| 欧美~级网站不卡| 亚洲在线电影| 日韩欧美久久| 久久免费影院| 91精品综合| 一区二区三区网站| 国产日韩精品视频一区二区三区| 精品三区视频| 欧美特黄一区| 日韩精品1区2区3区| 国产在线不卡一区二区三区| 亚洲h色精品| 蜜桃av一区二区| 国产激情久久| 久久久一二三| 另类av一区二区| 7777精品| 中文一区一区三区高中清不卡免费| 国产99精品一区| 日本伊人午夜精品| 福利一区二区| 午夜在线观看免费一区| 麻豆精品久久| 精品一区在线| 欧美日韩一区二区三区四区在线观看 | 国产欧美高清| 日韩成人亚洲| 亚洲欧洲国产精品一区| 欧美韩一区二区| 黄色精品网站| 国产精品qvod| 日韩亚洲在线| 国产精品羞羞答答在线观看| 久久免费国产| 欧美三级第一页| 国产一区日韩欧美| 综合亚洲视频| 欧美sm一区| 日韩黄色av| 一区二区三区视频免费观看| 日韩精品社区| 免费不卡中文字幕在线| 日韩毛片一区| 欧美亚洲精品在线| 国产精品三级| 伊人久久成人| 精品国产一区二区三区性色av| 99pao成人国产永久免费视频| 欧美精品91| 蜜臀精品久久久久久蜜臀| 在线中文字幕播放| 午夜精品福利影院| 日韩精品麻豆| 国产精东传媒成人av电影| 久久高清一区| 欧美天堂视频| 国产亚洲观看|