Python logging

import logging
'''
默認情況下Python的logging模塊將日誌打印到了標準輸出中,且只顯示了大於等於WARNING級別的日誌,
這說明默認的日誌級別設置爲WARNING(日誌級別等級CRITICAL > ERROR > WARNING > INFO > DEBUG),
默認的日誌格式爲日誌級別:Logger名稱:用戶輸出消息。
可見在logging.basicConfig()函數中可通過具體參數來更改logging模塊默認行爲,可用參數有
filename:用指定的文件名創建FiledHandler(後邊會具體講解handler的概念),這樣日誌會被存儲在指定的文件中。
filemode:文件打開方式,在指定了filename時使用這個參數,默認值爲“a”還可指定爲“w”。
format:指定handler使用的日誌顯示格式。
datefmt:指定日期時間格式。
level:設置rootlogger(後邊會講解具體概念)的日誌級別。
stream:用指定的stream創建StreamHandler。可以指定輸出到sys.stderr,sys.stdout或者文件(f=open('test.log','w')),默認爲sys.stderr。
若同時列出了filename和stream兩個參數,則stream參數會被忽略。
format參數中可能用到的格式化串:
%(name)s Logger的名字
%(levelno)s 數字形式的日誌級別
%(levelname)s 文本形式的日誌級別
%(pathname)s 調用日誌輸出函數的模塊的完整路徑名,可能沒有
%(filename)s 調用日誌輸出函數的模塊的文件名
%(module)s 調用日誌輸出函數的模塊名
%(funcName)s 調用日誌輸出函數的函數名
%(lineno)d 調用日誌輸出函數的語句所在的代碼行
%(created)f 當前時間,用UNIX標準的表示時間的浮 點數表示
%(relativeCreated)d 輸出日誌信息時的,自Logger創建以 來的毫秒數
%(asctime)s 字符串形式的當前時間。默認格式是 “2003-07-08 16:49:45,896”。逗號後面的是毫秒
%(thread)d 線程ID。可能沒有
%(threadName)s 線程名。可能沒有
%(process)d 進程ID。可能沒有
%(message)s用戶輸出的消息

logging庫提供了多個組件:Logger、Handler、Filter、Formatter。Logger對象提供應用程序可直接使用的接口,Handler發送日誌到適當的目的地,Filter提供了過濾日誌信息的方法,Formatter指定日誌顯示格式。
Logger是一個樹形層級結構,輸出信息之前都要獲得一個Logger(如果沒有顯示的獲取則自動創建並使用root Logger)。
logger = logging.getLogger()返回一個默認的Logger也即root Logger,並應用默認的日誌級別、Handler和Formatter設置。
當然也可以通過Logger.setLevel(lel)指定最低的日誌級別,可用的日誌級別有logging.DEBUG、logging.INFO、logging.WARNING、logging.ERROR、logging.CRITICAL。
Logger.debug()、Logger.info()、Logger.warning()、Logger.error()、Logger.critical()輸出不同級別的日誌,只有日誌等級大於或等於設置的日誌級別的日誌纔會被輸出。

'''
logging.basicConfig(level=logging.DEBUG, # 配置日誌級別,默認輸出debug等級及等級更高的內容
format='%(asctime)s--->%(filename)s[line:%(lineno)d]====>%(levelname)s::::%(message)s', # 配置日誌顯示格式
datefmt='%a, %d %b %Y %H:%M:%S', # 配置時間格式
filename='test.log', # 配置文件路徑
filemode='a') # 配置文件權限
logging.debug('debug message')
logging.warning('warning message')

示例4: 只在屏幕文件中寫入日誌,不在屏幕上面顯示

def logger():
logger = logging.getLogger() # 創建一個大對象
fh = logging.FileHandler("test_log") # 向文件裏發送內容,並且給個參數,作用是:定義一個文件名,往文件裏寫入內容
ch=logging.StreamHandler() #向屏幕上發送內容
fm = logging.Formatter("%(asctime)s--->%(filename)s[line:%(lineno)d]====>%(levelname)s::::%(message)s") # 這個也是一個對象,作用是:定義日誌格式
fh.setFormatter(fm) # 往文件裏寫內容
ch.setFormatter(fm) #往屏幕上輸出內容
logger.addHandler(fh) # 對象,類似於吸別人內力,把fh吃掉
logger.addHandler(ch) #對象,類似於吸別人內力,把ch吃掉
logger.setLevel("DEBUG") # 設置日誌級別,控制日誌輸入多少條信息
return logger

-------------從這裏開始都是在操作log----------------

logger = logger() # 這個日誌就做成了一個接口,在其它地方,直接調用他就可以啦!
logger.debug("debug") # 輸出日誌的級別
logger.info("info")
logger.warning("warning")
logger.error("error")
logger.critical("critical")

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章