Python標準日志模塊logging簡介

jopen 12年前發布 | 62K 次閱讀 Python Python開發

前一段工作的時候用到了python寫后臺系統,需要把一些系統的行為記錄下來。本著不要去重復發明輪子的精神,就去搜索了一下python的系統庫本身是否有寫日志的模塊。果然有。python語言作為一門接口簡單,標準庫強大的語言,果然沒有令我失望。

簡單的使用方法

python的標準庫里的日志系統從Python2.3開始支持。只要import logging這個模塊即可使用。如果你想把日志寫入指定的一個文件中,只要這樣使用:

import logging
logging.basicConfig(filename='example.log',level=logging.DEBUG)
logging.debug('This message should go to the log file')
logging.info('So should this')
logging.warning('And this %s %d, too','123',1)

basicConfig是指定文件的路徑和日志的級別。

日志一共分成5個等級,從低到高分別是:DEBUG INFO WARNING ERROR CRITICAL。這5個等級,也分別對應5種打日志的方法: debug info ,warning error critical。這5種方法都是類似C語言的printf的方法。 在basicConfig中設置的是日志的最低級別,換句話說,在程序中,只有使用了更高等級的日志信息才會打印出來。 比如你設置的日志級別是logging.INFO, 那么只有使用info, warning, error, critical這4種方法日志才會被記錄下來,debug的日志將會被忽略。

用上面的方法,簡單的日志就可以被打印出來了。不過logging模塊的功能非常強大,你還可以通過更加自由的接口,自定義出更復雜的日志形式。需要用到下面3種對象:

logger formatter handler .

logger

logger對象直接提供日志接口。formatter描述日志的格式。handler把日志寫到不同的地方,你可以把日志保存成本地文件,也可以每個小時寫一個日志文件,還可以把日志通過socket傳到別的機器上。

從最簡單的formatter對象來看。formatter指定的是每一條日志記錄的抬頭信息,也就是你可以指定日志記錄的時間格式、進程號、文件名、函數名等信息。可以用這個方法來創建一個formatter對象:

logging.Formatter.__init__( fmt=None, datefmt=None)

fmt參數指定進程號、文件名、函數名等信息是否出現以及格式, datefmt為日期時間格式,默認的日期格式精確到微秒,例如‘2003-07-08 16:49:45,896’。fmt中可以指定多個字段,每個字段的格式為“%( key>)s”, 例如你想打印時間、日志級別、日志信息可以用下面的format:

'%(asctime)s - %(levelname)s - %(message)s'

所有的可以使用的字段如下表:

Python標準日志模塊logging簡介

hander

通過handler對象可以把日志內容寫到不同的地方。比如簡單的StreamHandler就是把日志寫到類似文件的地方。python提供了十幾種實用handler,比較常用和比較有意思的我列舉一下:

StreamHandler 寫入類文件的流。

BaseRotatingHandler 可以按時間寫入到不同的日志中。比如將日志按天寫入不同的日期結尾的文件文件。

SocketHandler 用TCP網絡連接寫LOG

DatagramHandler 用UDP網絡連接寫LOG

SMTPHandler 把LOG寫成EMAIL郵寄出去

等等

簡單的例子來說明下 formatter handler logger 3個對象之間的交互吧。

#!/usr/bin/python
#coding: utf-8

import logging
import logging.handlers

logger = logging.getLogger()
logger.setLevel(logging.DEBUG)

rh=logging.handlers.TimedRotatingFileHandler('loggertester','D')
fm=logging.Formatter("%(asctime)s  %(levelname)s - %(message)s","%Y-%m-%d %H:%M:%S")
rh.setFormatter(fm)
logger.addHandler(rh)

debug=logger.debug
info=logger.info
warn=logger.warn
error=logger.error
critical=logger.critical

info("testlog1")
warn("warn you %s","costaxu")
critical("it is critical")

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!