国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

詳解Python自建logging模塊

2020-02-22 23:02:31
字體:
供稿:網(wǎng)友

簡單使用

最開始,我們用最短的代碼體驗一下logging的基本功能。

import logginglogger = logging.getLogger()logging.basicConfig()logger.setLevel('DEBUG')logger.debug('logsomething')#輸出out>>DEBG:root:logsomething

第一步,通過logging.getLogger函數(shù),獲取一個loger對象,但這個對象暫時是無法使用的。
第二步,logging.basicConfig函數(shù),進行一系列默認的配置,包括format、handler等。
第三步,logger調(diào)用setLevel函數(shù)定義日志級別為DEBUG 最后,調(diào)用debug函數(shù),輸出一條debug級別的message,顯示在了標準輸出上。 logging中的日志級別

logging在生成日志的時候,有一個日志級別的機制,默認有以下幾個日志級別:

CRITICAL = 50ERROR = 40WARNING = 30INFO 20DEBUG = 10NOTEST = 0

每一個logger對象,都有一個日志級別,它只會輸出高于它level的日志。如果一個logger的level是INFO,那么調(diào)用logger.debug()是無法輸出日志的,而logger.warning()能夠輸出。

一般來說,以上的6個日志級別完全滿足我們?nèi)粘J褂昧恕?/p>

logging中的基礎(chǔ)類

logging是python的一個基礎(chǔ)模塊,它在python中的源碼位置如下:

#主干代碼/usr/lib/python2.7/logging/__init__.py#擴展的handler和config/usr/lib/pyhon2.7/logging/config.py/usr/lib/python2.7/loging/handlers.py

組成logging的主干的幾個基礎(chǔ)類都在__init__.py中:

第一個基礎(chǔ)類LogRecord

一個LogRecord對象,對應(yīng)了日志中的一行數(shù)據(jù)。通常包含:時間、日志級別、message信息、當前執(zhí)行的模塊、行號、函數(shù)名...這些信息都包含在一個LogRecord對象里。
LogRecord對象可以想象成一個大字典:

class LogRecord(object): #代表一條日志的類 def getMessage(self):  #獲取self.msg def markLogRecord(dict): #這個方法很重要,生成一個空的LogRecord,然后通過一個字典,直接更新LogReocrd中的成員變量 rv = LogRecord(None, None, "", 0, "", (), None, None) rv.__dict__.update(dict) return rv

第二個基礎(chǔ)類Formatter

Formatter對象是用來定義日志格式的,LogRecord保存了很多信息,但是打印日志的時候我們只需要其中幾個,F(xiàn)ormatter就提供了這樣的功能,它依賴于python的一個功能:

#通過字典的方式,輸出格式化字符串print('%(name)s:%(num)d'%{'name':'my_name', 'num' : 100})out >>>my_name:100
如果說LogRecord是后面的那個字典,那么Formatter就是前面的那個格式字符串...的抽象

重要的代碼如下:

class Formatter(object): def __init__(self, fmt=None, datefmt = None):  if fmt:   self._fmt = fmt  else:   #默認的format   self._fmt = "%(message)s" def format(self, record)  #使用self._fmt進行格式化  s = self._fmt %record.__dict__  return s            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 乌兰县| 资源县| 嘉祥县| 辽阳县| 若羌县| 茶陵县| 伽师县| 延川县| 海伦市| 沂南县| 大英县| 邹平县| 乌审旗| 巴彦淖尔市| 周宁县| 汤原县| 泰兴市| 灵丘县| 同仁县| 江陵县| 蓝田县| 邵东县| 苍梧县| 大邑县| 泗洪县| 龙游县| 保康县| 望城县| 宝丰县| 临汾市| 桦川县| 兰坪| 丁青县| 精河县| 琼结县| 东丽区| 平顶山市| 忻州市| 阳谷县| 建平县| 泰宁县|