python 的日志logging模塊

python 的日志logging模塊學習

1.簡單的將日志打印到屏幕

import logging

logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')

屏幕上打印:

WARNING:root:This is warning message

默認情況下宣蠕,logging將日志打印到屏幕笛园,日志級別為WARNING兜挨;

日志級別大小關系為:CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET退唠,當然也可以自己定義日志級別箩艺。

2.通過logging.basicConfig函數(shù)對日志的輸出格式及方式做相關配置

import logging

logging.basicConfig(level=logging.DEBUG,
                format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
                datefmt='%a, %d %b %Y %H:%M:%S',
                filename='myapp.log',
                filemode='w')
    
logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')
 
./myapp.log文件中內容為:
Sun, 24 May 2009 21:48:54 demo2.py[line:11] DEBUG This is debug message
Sun, 24 May 2009 21:48:54 demo2.py[line:12] INFO This is info message
Sun, 24 May 2009 21:48:54 demo2.py[line:13] WARNING This is warning message
    
    logging.basicConfig函數(shù)各參數(shù):
    filename: 指定日志文件名
    filemode: 和file函數(shù)意義相同窜醉,指定日志文件的打開模式,'w'或'a'
    format: 指定輸出的格式和內容艺谆,format可以輸出很多有用信息榨惰,如上例所示:
     %(levelno)s: 打印日志級別的數(shù)值
     %(levelname)s: 打印日志級別名稱
     %(pathname)s: 打印當前執(zhí)行程序的路徑,其實就是sys.argv[0]
     %(filename)s: 打印當前執(zhí)行程序名
     %(funcName)s: 打印日志的當前函數(shù)
     %(lineno)d: 打印日志的當前行號
     %(asctime)s: 打印日志的時間
     %(thread)d: 打印線程ID
     %(threadName)s: 打印線程名稱
     %(process)d: 打印進程ID
     %(message)s: 打印日志信息
    datefmt: 指定時間格式静汤,同time.strftime()
    level: 設置日志級別琅催,默認為logging.WARNING
    stream: 指定將日志的輸出流居凶,可以指定輸出到sys.stderr,sys.stdout或者文件,默認輸出到sys.stderr藤抡,當stream和filename同時指定時侠碧,stream被忽略

3.將日志同時輸出到文件和屏幕

import logging

logging.basicConfig(level=logging.DEBUG,
                format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
                datefmt='%a, %d %b %Y %H:%M:%S',
                filename='myapp.log',
                filemode='w')

#################################################################################################
#定義一個StreamHandler,將INFO級別或更高的日志信息打印到標準錯誤缠黍,并將其添加到當前的日志處理對象#
console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
console.setFormatter(formatter)
logging.getLogger('').addHandler(console)
#################################################################################################

logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')
 
屏幕上打印:
root        : INFO     This is info message
root        : WARNING  This is warning message
./myapp.log文件中內容為:
Sun, 24 May 2009 21:48:54 demo2.py[line:11] DEBUG This is debug message
Sun, 24 May 2009 21:48:54 demo2.py[line:12] INFO This is info message
Sun, 24 May 2009 21:48:54 demo2.py[line:13] WARNING This is warning message

4.logging之日志回滾

import logging
from logging.handlers import RotatingFileHandler

#################################################################################################
#定義一個RotatingFileHandler弄兜,最多備份5個日志文件,每個日志文件最大10M
Rthandler = RotatingFileHandler('myapp.log', maxBytes=10*1024*1024,backupCount=5)
Rthandler.setLevel(logging.INFO)
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
Rthandler.setFormatter(formatter)
logging.getLogger('').addHandler(Rthandler)
################################################################################################
從上例和本例可以看出瓷式,logging有一個日志處理的主對象替饿,其它處理方式都是通過addHandler添加進去的。
logging的幾種handle方式如下:
 
logging.StreamHandler: 日志輸出到流贸典,可以是sys.stderr盛垦、sys.stdout或者文件
logging.FileHandler: 日志輸出到文件
日志回滾方式,實際使用時用RotatingFileHandler和TimedRotatingFileHandler
logging.handlers.BaseRotatingHandler
logging.handlers.RotatingFileHandler
logging.handlers.TimedRotatingFileHandler
logging.handlers.SocketHandler: 遠程輸出日志到TCP/IP sockets
logging.handlers.DatagramHandler:  遠程輸出日志到UDP sockets
logging.handlers.SMTPHandler:  遠程輸出日志到郵件地址
logging.handlers.SysLogHandler: 日志輸出到syslog
logging.handlers.NTEventLogHandler: 遠程輸出日志到Windows NT/2000/XP的事件日志
logging.handlers.MemoryHandler: 日志輸出到內存中的制定buffer
logging.handlers.HTTPHandler: 通過"GET"或"POST"遠程輸出到HTTP服務器

由于StreamHandler和FileHandler是常用的日志處理方式瓤漏,所以直接包含在logging模塊中腾夯,而其他方式則包含在logging.handlers模塊中,

上述其它處理方式的使用請參見python2.5手冊蔬充!

5.通過logging.config模塊配置日志

#logger.conf
###############################################
[loggers]
keys=root,example01,example02
[logger_root]
level=DEBUG
handlers=hand01,hand02
[logger_example01]
handlers=hand01,hand02
qualname=example01
propagate=0
[logger_example02]
handlers=hand01,hand03
qualname=example02
propagate=0
###############################################
[handlers]
keys=hand01,hand02,hand03
[handler_hand01]
class=StreamHandler
level=INFO
formatter=form02
args=(sys.stderr,)
[handler_hand02]
class=FileHandler
level=DEBUG
formatter=form01
args=('myapp.log', 'a')
[handler_hand03]
class=handlers.RotatingFileHandler
level=INFO
formatter=form02
args=('myapp.log', 'a', 10*1024*1024, 5)
###############################################
[formatters]
keys=form01,form02
[formatter_form01]
format=%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s
datefmt=%a, %d %b %Y %H:%M:%S
[formatter_form02]
format=%(name)-12s: %(levelname)-8s %(message)s
datefmt=

上例3:

import logging
import logging.config

logging.config.fileConfig("logger.conf")
logger = logging.getLogger("example01")

logger.debug('This is debug message')
logger.info('This is info message')
logger.warning('This is warning message')

上例4:

import logging
import logging.config

logging.config.fileConfig("logger.conf")
logger = logging.getLogger("example02")

logger.debug('This is debug message')
logger.info('This is info message')
logger.warning('This is warning message')

6.logging是線程安全的

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末蝶俱,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子饥漫,更是在濱河造成了極大的恐慌榨呆,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件庸队,死亡現(xiàn)場離奇詭異积蜻,居然都是意外死亡,警方通過查閱死者的電腦和手機彻消,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進店門竿拆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人宾尚,你說我怎么就攤上這事丙笋。” “怎么了煌贴?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵御板,是天一觀的道長。 經(jīng)常有香客問我牛郑,道長怠肋,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任淹朋,我火速辦了婚禮笙各,結果婚禮上钉答,老公的妹妹穿的比我還像新娘。我一直安慰自己酪惭,他們只是感情好,可當我...
    茶點故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布者甲。 她就那樣靜靜地躺著春感,像睡著了一般。 火紅的嫁衣襯著肌膚如雪虏缸。 梳的紋絲不亂的頭發(fā)上鲫懒,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天,我揣著相機與錄音刽辙,去河邊找鬼窥岩。 笑死,一個胖子當著我的面吹牛宰缤,可吹牛的內容都是我干的颂翼。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼慨灭,長吁一口氣:“原來是場噩夢啊……” “哼朦乏!你這毒婦竟也來了?” 一聲冷哼從身側響起氧骤,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤呻疹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后筹陵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刽锤,經(jīng)...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年朦佩,在試婚紗的時候發(fā)現(xiàn)自己被綠了并思。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,654評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡语稠,死狀恐怖纺荧,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情颅筋,我是刑警寧澤宙暇,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站议泵,受9級特大地震影響占贫,放射性物質發(fā)生泄漏。R本人自食惡果不足惜先口,卻給世界環(huán)境...
    茶點故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一型奥、第九天 我趴在偏房一處隱蔽的房頂上張望瞳收。 院中可真熱鬧,春花似錦厢汹、人聲如沸螟深。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽界弧。三九已至,卻和暖如春搭综,著一層夾襖步出監(jiān)牢的瞬間垢箕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工兑巾, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留条获,地道東北人。 一個月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓蒋歌,卻偏偏與公主長得像帅掘,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子堂油,可洞房花燭夜當晚...
    茶點故事閱讀 43,543評論 2 349

推薦閱讀更多精彩內容

  • 1.簡單的將日志打印到屏幕 屏幕上打印: 默認情況下锄开,logging將日志打印到屏幕,日志級別為WARNING称诗;日...
    大明白閱讀 1,639評論 0 49
  • 前言 在自動化測試實踐過程中萍悴,必不可少的就是進行日志管理,方便調試和生產問題追蹤寓免,python提供了logg...
    苦葉子閱讀 809評論 0 0
  • 本文翻譯自logging howto 基礎教程 日志是跟蹤軟件運行時發(fā)生事件的一種手段癣诱。Python開發(fā)者在代碼中...
    大蟒傳奇閱讀 4,251評論 0 17
  • 本文章是我大概三年前,在上家單位使用 Python 工作時結合官方文檔做的整理⊥嘞悖現(xiàn)在 Python 官方文檔聽說已...
    好吃的野菜閱讀 216,541評論 14 232
  • 工作撕予,生活,我們每一天都在與不同的人溝通蜈首,溝通的方式?jīng)Q定了溝通的效果实抡。 溝通不是想當然,是真實的達到了意見的統(tǒng)一欢策。...
    紅雲(yún)說口才閱讀 123評論 0 0