99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀Python內(nèi)置模塊logging用法實(shí)例分析
Python內(nèi)置模塊logging用法實(shí)例分析
2018-04-10
收藏

Python內(nèi)置模塊logging用法實(shí)例分析

本文實(shí)例講述了Python內(nèi)置模塊logging用法。分享給大家供大家參考,具體如下:
1、將日志直接輸出到屏幕    
import logging
logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')
# 默認(rèn)情況下,logging將日志打印到屏幕,日志級別為WARNING;
#output====================================
# WARNING:root:This is warning message

2.通過logging.basicConfig函數(shù)對日志的輸出格式及方式做相關(guān)配置    
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文件中內(nèi)容為:
#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ù):

#logging.basicConfig函數(shù)各參數(shù):
filename: 指定日志文件名
filemode: 和file函數(shù)意義相同,指定日志文件的打開模式,'w'或'a'
format: 指定輸出的格式和內(nèi)容,format可以輸出很多有用信息,如上例所示:
    %(levelno)s:     打印日志級別的數(shù)值
    %(levelname)s:     打印日志級別名稱
    %(pathname)s:     打印當(dāng)前執(zhí)行程序的路徑,其實(shí)就是sys.argv[0]
    %(filename)s:     打印當(dāng)前執(zhí)行程序名
    %(funcName)s:     打印日志的當(dāng)前函數(shù)
    %(lineno)d:     打印日志的當(dāng)前行號
    %(asctime)s:     打印日志的時(shí)間
    %(thread)d:     打印線程ID
    %(threadName)s: 打印線程名稱
    %(process)d:     打印進(jìn)程ID
    %(message)s:     打印日志信息
datefmt:     指定時(shí)間格式,同time.strftime()
level:         設(shè)置日志級別,默認(rèn)為logging.WARNING
stream:     指定將日志的輸出流,可以指定輸出到sys.stderr,sys.stdout或者文件,默認(rèn)輸出到sys.stderr,當(dāng)stream和filename同時(shí)指定時(shí),stream被忽略

3、將日志同時(shí)輸出到多個(gè)Handler

先定義一個(gè)住handler,并使用addHander()添加到主handler,實(shí)現(xiàn)日志輸出到多個(gè)handler.

a、同時(shí)輸出到文件和屏幕

import logging
#設(shè)置一個(gè)basicConfig只能輸出到一個(gè)Handler
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')
#定義一個(gè)StreamHandler,將INFO級別或更高的日志信息打印到標(biāo)準(zhǔn)錯(cuò)誤,并將其添加到當(dāng)前的日志處理對象#
console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
console.setFormatter(formatter)
logging.getLogger('').addHandler(console)
#輸出到文件的log級別為debug,輸出到stream的log級別為info
logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')

b、添加一個(gè)handler:輸出到文件,并根據(jù)文件大小滾動(dòng)存儲

在a的基礎(chǔ)上添加一個(gè)handler    
from logging.handlers import RotatingFileHandler
#定義一個(gè)RotatingFileHandler,最多備份5個(gè)日志文件,每個(gè)日志文件最大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幾種Handler類型:

logging.StreamHandler(默認(rèn)):     日志輸出到流,可以是sys.stderr、sys.stdout或者文件
logging.FileHandler:             日志輸出到文件
logging.handlers.RotatingFileHandler    日志輸出到文件,基于文件大小滾動(dòng)存儲日志
logging.handlers.TimedRotatingFileHandler    日志輸出到文件,基于時(shí)間周期滾動(dòng)存儲日志
logging.handlers.SocketHandler:     遠(yuǎn)程輸出日志到TCP/IP sockets
logging.handlers.DatagramHandler:      遠(yuǎn)程輸出日志到UDP sockets
logging.handlers.SMTPHandler:          遠(yuǎn)程輸出日志到郵件地址
logging.handlers.SysLogHandler:     日志輸出到syslog
logging.handlers.NTEventLogHandler: 遠(yuǎn)程輸出日志到Windows NT/2000/XP的事件日志
logging.handlers.MemoryHandler:     日志輸出到內(nèi)存中的制定buffer
logging.handlers.HTTPHandler:         通過"GET"或"POST"遠(yuǎn)程輸出到HTTP服務(wù)器

4、通過配置文件配置logger

a、定義配置文件logger.conf

#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=
b、logging.config獲取配置    
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')    
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')



數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個(gè)參數(shù)驗(yàn)證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個(gè)配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時(shí)表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時(shí)完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }