欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年08月04日 08:24:26   作者:David Beazley  
這篇文章主要介紹了Python如何給函數庫增加日志功能,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下

問題

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

解決方案

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

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

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

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

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

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

討論

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

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

log.addHandler(logging.NullHandler()) 操作將一個空處理器綁定到剛剛已經創(chuàng)建好的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級別的消息,它的優(yōu)先級比全局配置高。 像這樣更改單獨模塊的日志配置對于調試來講是很方便的, 因為你無需去更改任何的全局日志配置——只需要修改你想要更多輸出的模塊的日志等級。

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

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

相關文章

  • python按修改時間順序排列文件的實例代碼

    python按修改時間順序排列文件的實例代碼

    這篇文章主要介紹了python按修改時間順序排列文件的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-07-07
  • Python中關于使用模塊的基礎知識

    Python中關于使用模塊的基礎知識

    這篇文章主要介紹了Python中關于使用模塊的基礎知識,是Python入門的基礎,需要的朋友可以參考下
    2015-05-05
  • 詳解Python中的變量及其命名和打印

    詳解Python中的變量及其命名和打印

    這篇文章主要介紹了Python中的變量及其命名和打印,是Python入門學習中的基礎知識,需要的朋友可以參考下
    2016-03-03
  • Python2.x中str與unicode相關問題的解決方法

    Python2.x中str與unicode相關問題的解決方法

    這篇文章主要介紹了Python2.x中str與Unicode相關問題的解決方法,Python2.x版本中由于沒有默認使用Unicode而會在實際使用中碰到一些字符問題,針對這些問題本文討論了一些解決方法,需要的朋友可以參考下
    2015-03-03
  • Linux上安裝Python的PIL和Pillow庫處理圖片的實例教程

    Linux上安裝Python的PIL和Pillow庫處理圖片的實例教程

    這里我們來看一下在Linux上安裝Python的PIL和Pillow庫處理圖片的實例教程,包括一個使用Pillow庫實現批量轉換圖片的例子:
    2016-06-06
  • 利用Anaconda創(chuàng)建虛擬環(huán)境的全過程

    利用Anaconda創(chuàng)建虛擬環(huán)境的全過程

    因為多次重新配置環(huán)境,這些命令每次都要用,每次都忘記,需要重新搜索,所以記錄這一過程,下面這篇文章主要給大家介紹了關于利用Anaconda創(chuàng)建虛擬環(huán)境的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • Django 路由控制的實現

    Django 路由控制的實現

    這篇文章主要介紹了Django 路由控制的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • Python cookbook(數據結構與算法)從序列中移除重復項且保持元素間順序不變的方法

    Python cookbook(數據結構與算法)從序列中移除重復項且保持元素間順序不變的方法

    這篇文章主要介紹了Python cookbook(數據結構與算法)從序列中移除重復項且保持元素間順序不變的方法,涉及Python針對列表與字典的元素遍歷、判斷、去重、排序等相關操作技巧,需要的朋友可以參考下
    2018-03-03
  • Python中列表與元組的乘法操作示例

    Python中列表與元組的乘法操作示例

    這篇文章主要介紹了Python中列表與元組的乘法操作,結合簡單實例形式分析了Python中列表、元組的乘法,并附帶分析了字符串的乘法及元組乘法操作的注意事項,需要的朋友可以參考下
    2018-02-02
  • python str轉json的具體步驟

    python str轉json的具體步驟

    使用Python內置的json模塊,可以將str轉換為JSON,本文給大家介紹python str轉json的具體步驟,文中補充介紹了Python-字符串str和json格式的轉換問題,感興趣的朋友一起看看吧
    2024-01-01

最新評論