亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python如何給函數庫增加日志功能

瀏覽:136日期:2022-07-15 10:43:03

問題

你想給某個函數庫增加日志功能,但是又不能影響到那些不使用日志功能的程序。

解決方案

對于想要執行日志操作的函數庫而已,你應該創建一個專屬的 logger 對象,并且像下面這樣初始化配置:

# 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’)

使用這個配置,默認情況下不會打印日志。例如:

>>> import somelib>>> somelib.func()>>>

不過,如果配置過日志系統,那么日志消息打印就開始生效,例如:

>>> import logging>>> logging.basicConfig()>>> somelib.func()CRITICAL:somelib:A Critical Error!>>>

討論

通常來講,你不應該在函數庫代碼中自己配置日志系統,或者是已經假定有個已經存在的日志配置了。

調用 getLogger(__name__) 創建一個和調用模塊同名的logger模塊。 由于模塊都是唯一的,因此創建的logger也將是唯一的。

log.addHandler(logging.NullHandler()) 操作將一個空處理器綁定到剛剛已經創建好的logger對象上。 一個空處理器默認會忽略調用所有的日志消息。 因此,如果使用該函數庫的時候還沒有配置日志,那么將不會有消息或警告出現。

還有一點就是對于各個函數庫的日志配置可以是相互獨立的,不影響其他庫的日志配置。 例如,對于如下的代碼:

>>> 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或更高級別的消息。 不過 ,somelib 的日志級別被單獨配置成可以輸出debug級別的消息,它的優先級比全局配置高。 像這樣更改單獨模塊的日志配置對于調試來講是很方便的, 因為你無需去更改任何的全局日志配置——只需要修改你想要更多輸出的模塊的日志等級。

Logging HOWTO 詳細介紹了如何配置日志模塊和其他有用技巧,可以參閱下。

以上就是Python如何給函數庫增加日志功能的詳細內容,更多關于Python給函數庫增加日志功能的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 天天色图| 一区二区三区久久精品 | 国产成人高清精品免费软件 | 黑人粗又长 | 成人免播放器午夜视频 | 久久五十路 | 青青青久在线视频免费观看 | 国产卡一卡二卡三 | 精品国产成人 | 看一级黄色 | 国产成人a大片大片在线播放 | 婷婷色爱区综合五月激情韩国 | 萌白酱粉嫩福利视频在线观看 | 九九黄色大片 | 亚洲a成人7777777久久 | 国产精品人人视频 | 国产精品亚洲一区二区三区久久 | 国产片91人成在线观看 | 1717she精品国产真正免费 | 视频二区在线 | 九九热中文字幕 | 亚洲午夜18 | 国产精品久久福利新婚之夜 | 国产精品久久久久久免费 | 久在线精品视频 | 亚洲综合精品一区 | 欧美一区视频 | 欧美精品亚洲精品日韩经典 | 97超在线 | 国产精品久久久久影院色老大 | 国产精品黄大片在线播放 | 三级国产在线观看 | 久久黄色影院 | 丁香婷婷激情综合 | 中文字幕一区二区三区在线不卡 | 亚洲国产第一区二区三区 | 在线观看日本免费视频大片 | 欧美精品国产一区二区 | 色综合合久久天天给综看 | 看黄网站在线观看 | 91香蕉视频免费在线观看 |