Python如何給函數(shù)庫(kù)增加日志功能
問題
你想給某個(gè)函數(shù)庫(kù)增加日志功能,但是又不能影響到那些不使用日志功能的程序。
解決方案
對(duì)于想要執(zhí)行日志操作的函數(shù)庫(kù)而已,你應(yīng)該創(chuàng)建一個(gè)專屬的 logger 對(duì)象,并且像下面這樣初始化配置:
# somelib.py import logging log = logging.getLogger(__name__) log.addHandler(logging.NullHandler()) # Example function (for testing) def func(): log.critical('A Critical Error!') log.debug('A debug message')
使用這個(gè)配置,默認(rèn)情況下不會(huì)打印日志。例如:
>>> import somelib >>> somelib.func() >>>
不過,如果配置過日志系統(tǒng),那么日志消息打印就開始生效,例如:
>>> import logging >>> logging.basicConfig() >>> somelib.func() CRITICAL:somelib:A Critical Error! >>>
討論
通常來講,你不應(yīng)該在函數(shù)庫(kù)代碼中自己配置日志系統(tǒng),或者是已經(jīng)假定有個(gè)已經(jīng)存在的日志配置了。
調(diào)用 getLogger(__name__)
創(chuàng)建一個(gè)和調(diào)用模塊同名的logger模塊。 由于模塊都是唯一的,因此創(chuàng)建的logger也將是唯一的。
log.addHandler(logging.NullHandler())
操作將一個(gè)空處理器綁定到剛剛已經(jīng)創(chuàng)建好的logger對(duì)象上。 一個(gè)空處理器默認(rèn)會(huì)忽略調(diào)用所有的日志消息。 因此,如果使用該函數(shù)庫(kù)的時(shí)候還沒有配置日志,那么將不會(huì)有消息或警告出現(xiàn)。
還有一點(diǎn)就是對(duì)于各個(gè)函數(shù)庫(kù)的日志配置可以是相互獨(dú)立的,不影響其他庫(kù)的日志配置。 例如,對(duì)于如下的代碼:
>>> import logging >>> logging.basicConfig(level=logging.ERROR) >>> import somelib >>> somelib.func() CRITICAL:somelib:A Critical Error! >>> # Change the logging level for 'somelib' only >>> logging.getLogger('somelib').level=logging.DEBUG >>> somelib.func() CRITICAL:somelib:A Critical Error! DEBUG:somelib:A debug message >>>
在這里,根日志被配置成僅僅輸出ERROR或更高級(jí)別的消息。 不過 ,somelib
的日志級(jí)別被單獨(dú)配置成可以輸出debug級(jí)別的消息,它的優(yōu)先級(jí)比全局配置高。 像這樣更改單獨(dú)模塊的日志配置對(duì)于調(diào)試來講是很方便的, 因?yàn)槟銦o需去更改任何的全局日志配置——只需要修改你想要更多輸出的模塊的日志等級(jí)。
Logging HOWTO 詳細(xì)介紹了如何配置日志模塊和其他有用技巧,可以參閱下。
以上就是Python如何給函數(shù)庫(kù)增加日志功能的詳細(xì)內(nèi)容,更多關(guān)于Python給函數(shù)庫(kù)增加日志功能的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- python統(tǒng)計(jì)函數(shù)庫(kù)scipy.stats的用法解析
- Python隨機(jī)函數(shù)庫(kù)random的使用方法詳解
- 詳解python中的Turtle函數(shù)庫(kù)
- Python logging日志模塊 配置文件方式
- 詳解python logging日志傳輸
- python3中的logging記錄日志實(shí)現(xiàn)過程及封裝成類的操作
- python實(shí)時(shí)監(jiān)控logstash日志代碼
- Python日志logging模塊功能與用法詳解
- 使用Python將Exception異常錯(cuò)誤堆棧信息寫入日志文件
- 解決Python logging模塊無法正常輸出日志的問題
相關(guān)文章
python按修改時(shí)間順序排列文件的實(shí)例代碼
這篇文章主要介紹了python按修改時(shí)間順序排列文件的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-07-07Python中關(guān)于使用模塊的基礎(chǔ)知識(shí)
這篇文章主要介紹了Python中關(guān)于使用模塊的基礎(chǔ)知識(shí),是Python入門的基礎(chǔ),需要的朋友可以參考下2015-05-05Python2.x中str與unicode相關(guān)問題的解決方法
這篇文章主要介紹了Python2.x中str與Unicode相關(guān)問題的解決方法,Python2.x版本中由于沒有默認(rèn)使用Unicode而會(huì)在實(shí)際使用中碰到一些字符問題,針對(duì)這些問題本文討論了一些解決方法,需要的朋友可以參考下2015-03-03Linux上安裝Python的PIL和Pillow庫(kù)處理圖片的實(shí)例教程
這里我們來看一下在Linux上安裝Python的PIL和Pillow庫(kù)處理圖片的實(shí)例教程,包括一個(gè)使用Pillow庫(kù)實(shí)現(xiàn)批量轉(zhuǎn)換圖片的例子:2016-06-06利用Anaconda創(chuàng)建虛擬環(huán)境的全過程
因?yàn)槎啻沃匦屡渲铆h(huán)境,這些命令每次都要用,每次都忘記,需要重新搜索,所以記錄這一過程,下面這篇文章主要給大家介紹了關(guān)于利用Anaconda創(chuàng)建虛擬環(huán)境的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)從序列中移除重復(fù)項(xiàng)且保持元素間順序不變的方法
這篇文章主要介紹了Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)從序列中移除重復(fù)項(xiàng)且保持元素間順序不變的方法,涉及Python針對(duì)列表與字典的元素遍歷、判斷、去重、排序等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03