Python如何給函數(shù)庫(kù)增加日志功能
問(wèn)題
你想給某個(gè)函數(shù)庫(kù)增加日志功能,但是又不能影響到那些不使用日志功能的程序。
解決方案
對(duì)于想要執(zhí)行日志操作的函數(shù)庫(kù)而已,你應(yīng)該創(chuàng)建一個(gè)專屬的 logger 對(duì)象,并且像下面這樣初始化配置:
# somelib.pyimport logginglog = 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()>>>
不過(guò),如果配置過(guò)日志系統(tǒng),那么日志消息打印就開(kāi)始生效,例如:
>>> import logging>>> logging.basicConfig()>>> somelib.func()CRITICAL:somelib:A Critical Error!>>>
討論
通常來(lái)講,你不應(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í)候還沒(méi)有配置日志,那么將不會(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í)別的消息。 不過(guò) ,somelib 的日志級(jí)別被單獨(dú)配置成可以輸出debug級(jí)別的消息,它的優(yōu)先級(jí)比全局配置高。 像這樣更改單獨(dú)模塊的日志配置對(duì)于調(diào)試來(lái)講是很方便的, 因?yàn)槟銦o(wú)需去更改任何的全局日志配置——只需要修改你想要更多輸出的模塊的日志等級(jí)。
Logging HOWTO 詳細(xì)介紹了如何配置日志模塊和其他有用技巧,可以參閱下。
以上就是Python如何給函數(shù)庫(kù)增加日志功能的詳細(xì)內(nèi)容,更多關(guān)于Python給函數(shù)庫(kù)增加日志功能的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. CentOS郵箱服務(wù)器搭建系列——SMTP服務(wù)器的構(gòu)建( Postfix )2. Docker 啟動(dòng)Redis 并設(shè)置密碼的操作3. ASP新手必備的基礎(chǔ)知識(shí)4. PHP基礎(chǔ)之生成器4——比較生成器和迭代器對(duì)象5. asp文件用什么軟件編輯6. JAVA 實(shí)現(xiàn)延遲隊(duì)列的方法7. JS中6個(gè)對(duì)象數(shù)組去重的方法8. vue+element開(kāi)發(fā)一個(gè)谷歌插件的全過(guò)程9. 利用CSS制作3D動(dòng)畫10. vue限制輸入數(shù)字或者保留兩位小數(shù)實(shí)現(xiàn)

網(wǎng)公網(wǎng)安備