亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python中 logging的使用詳解

 更新時(shí)間:2017年10月25日 08:39:18   作者:Wanna_Go  
這篇文章主要介紹了python中 logging的使用,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

日志是用來(lái)記錄程序在運(yùn)行過(guò)程中發(fā)生的狀況,在程序開(kāi)發(fā)過(guò)程中添加日志模塊能夠幫助我們了解程序運(yùn)行過(guò)程中發(fā)生了哪些事件,這些事件也有輕重之分。

根據(jù)事件的輕重可分為以下幾個(gè)級(jí)別:

DEBUG: 詳細(xì)信息,通常僅在診斷問(wèn)題時(shí)才受到關(guān)注。整數(shù)level=10

INFO: 確認(rèn)程序按預(yù)期工作。整數(shù)level=20

WARNING:出現(xiàn)了異常,但是不影響正常工作.整數(shù)level=30

ERROR:由于某些原因,程序 不能執(zhí)行某些功能。整數(shù)level=40

CRITICAL:嚴(yán)重的錯(cuò)誤,導(dǎo)致程序不能運(yùn)行。整數(shù)level=50

默認(rèn)的級(jí)別是WARNING,也就意味著只有級(jí)別大于等于的才會(huì)被看到,跟蹤日志的方式可以是寫(xiě)入到文件中,也可以直接輸出到控制臺(tái)。

輸出到控制臺(tái)

下面是一個(gè)小例子通過(guò)將日志輸出到控制臺(tái)的方法:

import logging
logging.warning('Watch out!') # 將輸出到控制臺(tái)
logging.info('I told you so') # 不會(huì)輸出
logging.error("an error occurrence!") #將輸出到控制臺(tái)

輸出結(jié)果

WARNING:root:Watch out!
ERROR:root:an error occurrence

輸出到文件中

新開(kāi)一個(gè)python解釋器,確保不是上面代碼的session

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, too')

這個(gè)時(shí)候控制臺(tái)上面就沒(méi)有了輸出,文件example.log中的內(nèi)容

DEBUG:root:This message should go to the log file
INFO:root:So should this
WARNING:root:And this, too

假定需要手動(dòng)調(diào)整日志的級(jí)別,我們可以在命令行以參數(shù)的形式傳入--log=INFO,在代碼中可以采用下面的處理方式

# 輸入?yún)?shù) --log=DEBUG or --log=debug
numeric_level = getattr(logging, loglevel.upper(), None)#返回10,否則None
if not isinstance(numeric_level, int):
 raise ValueError('Invalid log level: %s' % loglevel)
logging.basicConfig(level=numeric_level, ...)

變量的日志

使用格式化字符串的方式,為變量添加日志

import logging
logging.warning('%s before you %s', 'Look', 'leap!')

自定義日志格式

我們還可以根據(jù)我們的需求自定義輸出模板

import logging
logging.basicConfig(format='%(asctime)s: %(levelname)s: %(message)s',level=logging.DEBUG)
logging.debug('This message should appear on the console')
logging.info('So should this')
logging.warning('And this, too')

輸出

2017-10-24 14:03:53,671: DEBUG: This message should appear on the console
2017-10-24 14:03:53,690: INFO: So should this
2017-10-24 14:03:53,694: WARNING: And this, too

內(nèi)部實(shí)際傳入的為一個(gè)字典,%(key)為字典的key。

上面是python logging模塊的一些基本用法, 已經(jīng)能夠滿(mǎn)足我們的許多需求,下面簡(jiǎn)單介紹下logging的一些高級(jí)用法。在logging模塊中主要包括logger,handlers,filter,formatters,這幾個(gè)組件

logger:提供了應(yīng)用接口,供程序使用
handlers:用來(lái)將logger創(chuàng)建的log 發(fā)送到相應(yīng)的目的地
filter:為要輸出的日志提供了更細(xì)粒度的設(shè)置
formatters:設(shè)置最終的輸出格式

下面是這幾個(gè)組件配合使用的例子

import logging
logger = logging.getLogger('logger_name')# 創(chuàng)建logger對(duì)象
logger.setLevel(logging.DEBUG)
handler = logging.StreamHandler()# 創(chuàng)建 console handler 并設(shè)置級(jí)別為debug
handler.setLevel(logging.DEBUG)
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')# 創(chuàng)建輸出格式
handler.setFormatter(formatter)# 為handler添加fromatter
logger.addHandler(handler)# 將handler添加到 logger
logger.debug('debug message')# 'application' code
logger.info('info message')
logger.warn('warn message')
logger.error('error message')
logger.critical('critical message')

輸出結(jié)果:

2017-10-24 16:50:43,127 - logger_name - DEBUG - debug message
2017-10-24 16:50:43,138 - logger_name - INFO - info message
2017-10-24 16:50:43,141 - logger_name - WARNING - warn message
2017-10-24 16:50:43,144 - logger_name - ERROR - error message
2017-10-24 16:50:43,148 - logger_name - CRITICAL - critical message

小應(yīng)用案例

下面是自己定義的一個(gè)日志處理方法,既能夠?qū)懭氲轿募校L動(dòng)保存近15天的日志,日志格式app.log, app.log.1, app.log.2),又能輸出到控制臺(tái)。

import logging
from logging.handlers import TimedRotatingFileHandler
class MylogHandler(logging.Logger):
 def __init__(self,name,level="DEBUG",stream=True,files=True):
  self.name = name
  self.level = level
  logging.Logger.__init__(self,self.name,level=self.level)
  if stream:
   self.__streamHandler__(self.level)
  if files:
   self.__filesHandler__(self.level)
 def __streamHandler__(self,level=None):
  handler = TimedRotatingFileHandler(filename=self.name+".log", when='D', interval=1, backupCount=15)
  handler.suffix = '%Y%m%d.log'
  handler.setLevel(level)
  formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s')
  handler.setFormatter(formatter)
  self.addHandler(handler) #將hander添加到logger上
 def __filesHandler__(self,level=None):
  handler = logging.StreamHandler()
  formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s')
  handler.setFormatter(formatter)
  handler.setLevel(level)
  self.addHandler(handler)
if __name__ == '__main__':
 log = MylogHandler('test')
 log.info('this is a my log handler')

總結(jié)

以上所述是小編給大家介紹的python中 logging的使用詳解,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Pytorch 高效使用GPU的操作

    Pytorch 高效使用GPU的操作

    這篇文章主要介紹了Pytorch 高效使用GPU的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-06-06
  • django反向解析和正向解析的方式

    django反向解析和正向解析的方式

    這篇文章主要介紹了django反向解析和正向解析的方式,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • ssh批量登錄并執(zhí)行命令的python實(shí)現(xiàn)代碼

    ssh批量登錄并執(zhí)行命令的python實(shí)現(xiàn)代碼

    有個(gè)任務(wù)是在這些電腦上執(zhí)行某些命令,者說(shuō)進(jìn)行某些操作,比如安裝某些軟件,拷貝某些文件,批量關(guān)機(jī)等。如果一臺(tái)一臺(tái)得手工去操作,費(fèi)時(shí)又費(fèi)力,如果要進(jìn)行多個(gè)操作就更麻煩啦
    2012-05-05
  • Python+OpenCV繪制多instance的Mask圖像

    Python+OpenCV繪制多instance的Mask圖像

    Mask圖像中,不同值表示不同的實(shí)例(instance)。本文將詳細(xì)為大家講講如何利用OpenCV繪制多instance的Mask圖像,感興趣的可以學(xué)習(xí)一下
    2022-06-06
  • 使用Python3 編寫(xiě)簡(jiǎn)單信用卡管理程序

    使用Python3 編寫(xiě)簡(jiǎn)單信用卡管理程序

    這篇文章主要介紹了使用Python3 編寫(xiě)簡(jiǎn)單信用卡管理程序的代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2016-12-12
  • python高級(jí)特性和高階函數(shù)及使用詳解

    python高級(jí)特性和高階函數(shù)及使用詳解

    Python很棒,它有很多高級(jí)用法值得細(xì)細(xì)思索,學(xué)習(xí)使用。這篇文章主要介紹了python高級(jí)特性和高階函數(shù)及使用詳解,需要的朋友可以參考下
    2018-10-10
  • 在python3.64中安裝pyinstaller庫(kù)的方法步驟

    在python3.64中安裝pyinstaller庫(kù)的方法步驟

    這篇文章主要介紹了在python3.64中安裝pyinstaller庫(kù)的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Python異常繼承關(guān)系和自定義異常實(shí)現(xiàn)代碼實(shí)例

    Python異常繼承關(guān)系和自定義異常實(shí)現(xiàn)代碼實(shí)例

    這篇文章主要介紹了Python異常繼承關(guān)系和自定義異常實(shí)現(xiàn)代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • 詳解Python二維數(shù)組與三維數(shù)組切片的方法

    詳解Python二維數(shù)組與三維數(shù)組切片的方法

    這篇文章主要介紹了詳解Python二維數(shù)組與三維數(shù)組切片的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • python從網(wǎng)絡(luò)讀取圖片并直接進(jìn)行處理的方法

    python從網(wǎng)絡(luò)讀取圖片并直接進(jìn)行處理的方法

    這篇文章主要介紹了python從網(wǎng)絡(luò)讀取圖片并直接進(jìn)行處理的方法,涉及cStringIO模塊模擬本地文件的使用技巧,需要的朋友可以參考下
    2015-05-05

最新評(píng)論