日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

够用的 Python 写日志的知识——标准日志模块logging简介

發(fā)布時(shí)間:2023/12/2 python 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 够用的 Python 写日志的知识——标准日志模块logging简介 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前一段工作的時(shí)候用到了python寫(xiě)后臺(tái)系統(tǒng),需要把一些系統(tǒng)的行為記錄下來(lái)。本著不要去重復(fù)發(fā)明輪子的精神,就去搜索了一下python的系統(tǒng)庫(kù)本身是否有寫(xiě)日志的模塊。果然有。python語(yǔ)言作為一門(mén)接口簡(jiǎn)單,標(biāo)準(zhǔn)庫(kù)強(qiáng)大的語(yǔ)言,果然沒(méi)有令我失望。

簡(jiǎn)單的使用方法

python的標(biāo)準(zhǔn)庫(kù)里的日志系統(tǒng)從Python2.3開(kāi)始支持。只要import logging這個(gè)模塊即可使用。如果你想把日志寫(xiě)入指定的一個(gè)文件中,只要這樣使用:

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是指定文件的路徑和日志的級(jí)別。

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

用上面的方法,簡(jiǎn)單的日志就可以被打印出來(lái)了。不過(guò)logging模塊的功能非常強(qiáng)大,你還可以通過(guò)更加自由的接口,自定義出更復(fù)雜的日志形式。需要用到下面3種對(duì)象:

logger formatter handler .

logger

logger對(duì)象直接提供日志接口。formatter描述日志的格式。handler把日志寫(xiě)到不同的地方,你可以把日志保存成本地文件,也可以每個(gè)小時(shí)寫(xiě)一個(gè)日志文件,還可以把日志通過(guò)socket傳到別的機(jī)器上。

從最簡(jiǎn)單的formatter對(duì)象來(lái)看。formatter指定的是每一條日志記錄的抬頭信息,也就是你可以指定日志記錄的時(shí)間格式、進(jìn)程號(hào)、文件名、函數(shù)名等信息。可以用這個(gè)方法來(lái)創(chuàng)建一個(gè)formatter對(duì)象:

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

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

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

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

hander

通過(guò)handler對(duì)象可以把日志內(nèi)容寫(xiě)到不同的地方。比如簡(jiǎn)單的StreamHandler就是把日志寫(xiě)到類似文件的地方。python提供了十幾種實(shí)用handler,比較常用和比較有意思的我列舉一下:

StreamHandler 寫(xiě)入類文件的流。

BaseRotatingHandler 可以按時(shí)間寫(xiě)入到不同的日志中。比如將日志按天寫(xiě)入不同的日期結(jié)尾的文件文件。

SocketHandler 用TCP網(wǎng)絡(luò)連接寫(xiě)LOG

DatagramHandler 用UDP網(wǎng)絡(luò)連接寫(xiě)LOG

SMTPHandler 把LOG寫(xiě)成EMAIL郵寄出去

等等

簡(jiǎn)單的例子來(lái)說(shuō)明下 formatter handler logger 3個(gè)對(duì)象之間的交互吧。

#!/usr/bin/python #coding: utf-8import logging import logging.handlerslogger = 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.criticalinfo("testlog1") warn("warn you %s","costaxu") critical("it is critical")

總結(jié)

以上是生活随笔為你收集整理的够用的 Python 写日志的知识——标准日志模块logging简介的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。