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

代碼解析python標準庫logging模塊

 更新時間:2022年05月20日 11:34:42   作者:wangst4321  
這篇文章主要為大家介紹了代碼解析python標準庫logging模塊,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

問題1:如何獲取caller的(文件名,行號,函數(shù)名)?

當新增一條log記錄時,最終將調(diào)用Logger類的_log方法,這個方法首先會創(chuàng)建一個LogRecord對象。LogRecord對象需要(filename, lineno, funcname)參數(shù)信息。這是通過如下語句得到的:

fn, lno, func = self.findCaller()  

findCaller內(nèi)容如下:

        f = currentframe()  #f是frame對象,每個方法調(diào)用生成一個frame對象,放在程序堆棧中。
        if f is not None:
            f = f.f_back
        rv = "(unknown file)", 0, "(unknown function)"
        while hasattr(f, "f_code"):
            co = f.f_code   #獲取code對象,它包含filename屬性,funcname屬性
            filename = os.path.normcase(co.co_filename)
            if filename == _srcfile:  #_srcfile是這個模塊文件自己的文件名,當文件名不再相同時
                f = f.f_back          # 得到外部調(diào)用者的frame,這就是需要的。
                continue
            rv = (filename, f.f_lineno, co.co_name)
            break
        return rv

currentframe函數(shù)的定義:

def currentframe():
    """Return the frame object for the caller's stack frame."""
    try:
        raise Exception    #拋出異常,將生成traceback對象,其中包含frame對象。
    except:
        #sys.exc_traceback.tb_frame當前的frame, f_back調(diào)用著的frame
        return sys.exc_traceback.tb_frame.f_back
#sys._getframe(3)返回的并不是當前的frame,3應(yīng)該是計算好了的,減少循環(huán)的次數(shù),返回的是logger.error()的frame
if hasattr(sys, '_getframe'): currentframe = lambda: sys._getframe(3)

問題2: Logger對象的層級,父子關(guān)系如何實現(xiàn)的?

首先,logging模塊中l(wèi)ogger層級關(guān)系是一個樹形關(guān)系的結(jié)構(gòu),這個關(guān)系的樹根是'root'。

root = RootLogger(WARNING)     #RootLogger類是Logger的子類,無特殊功能,只是定義名字為‘root'。
Logger.root = root
Logger.manager = Manager(Logger.root)

當調(diào)用logging.getLogger(),用以獲取某個Logger時,如果參數(shù)為空,則返回‘root’。否則,調(diào)用Manager的getLogger()方法獲取Logger。

def getLogger(name=None):
    """
    Return a logger with the specified name, creating it if necessary.
    If no name is specified, return the root logger.
    """
    if name:
        return Logger.manager.getLogger(name)
    else:
        return root

Manager的getLogger()定義如下:

    def getLogger(self, name):
        """
        Get a logger with the specified name (channel name), creating it
        if it doesn't yet exist. This name is a dot-separated hierarchical
        name, such as "a", "a.b", "a.b.c" or similar.
        If a PlaceHolder existed for the specified name [i.e. the logger
        didn't exist but a child of it did], replace it with the created
        logger and fix up the parent/child references which pointed to the
        placeholder to now point to the logger.
        """
        rv = None
        _acquireLock()
        try:
            if name in self.loggerDict:
                rv = self.loggerDict[name]
                if isinstance(rv, PlaceHolder):
                    ph = rv
                    rv = _loggerClass(name)
                    rv.manager = self
                    self.loggerDict[name] = rv
                    self._fixupChildren(ph, rv)
                    self._fixupParents(rv)
            else:
                rv = _loggerClass(name)
                rv.manager = self
                self.loggerDict[name] = rv
                self._fixupParents(rv)
        finally:
            _releaseLock()
        return rv

Manager對象中的loggerDict字典,存放logger名字和logger對象的映射關(guān)系。PlaceHolder類,是一個容器。

例如,名字為'sell'的PlaceHolder對象,首先還不存在'sell'的logger,然后,所以以'sell‘開頭的logger在這個對象內(nèi)都存在一個引用,如'sell.food','sell.cloth.china'等已有的logger對象。 當調(diào)用getLogger()獲取一個未存在的logger時,如名字為'level1.level2', 首先創(chuàng)建一個名字為'level1.level2'的logger對象,并存于loggerDict中。然后,調(diào)用_fixupParents()。

_fixupParents()的作用:

在這個名字的層級鏈上,找到第一個logger對象,將其作為父親,并返回。鏈上不是logger對象的名字,創(chuàng)建一個PlaceHolder對象(如果未創(chuàng)建),將自己加入其中。

例如,新增‘level1.level2.level3’的logger,調(diào)用_fixupParents將創(chuàng)建一個名字為'level1.level2‘的PlaceHolder對象,創(chuàng)建一個名字為’level1‘的PlaceHolder對象,并將’level1.level2.level3‘這個logger分別加入以上兩個PlaceHolder對象容器內(nèi),將它的父親設(shè)定為’root‘。

總之,_fixupParents是使logger對象指向真正的父親節(jié)點(logger對象),并將logger自己加入到所有上層的PlaceHolder對象容器內(nèi)。

如果獲取一個名字已存在于loggerDict中,并且這個名字對應(yīng)的是一個先前創(chuàng)建的PlaceHolder對象。首先,創(chuàng)建一個對應(yīng)名字的logger對象。然后,調(diào)用_fixupChild(),修正這個PlaceHolder對象所包含的下游logger對象的父親。最后,調(diào)用_fixupParent(),作用與上一步相同。

父子層級關(guān)系,主要作用是,當logger對象的propagate屬性值1(默認值)時,每條logRecord記錄都會傳給父logger處理。這樣可以只需要定義好‘root’根logger對象,其他的logger定義個名字,根據(jù)模塊名,類名等,然后綁定一個NullHandler。最后,所有的logRecord將交給’root‘統(tǒng)一處理處理。這是多模塊產(chǎn)生統(tǒng)一格式log的方式。

以上就是代碼解析python標準庫logging模塊的詳細內(nèi)容,更多關(guān)于python標準庫logging模塊的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 解讀sqlalchemy的常用數(shù)據(jù)類型有哪些

    解讀sqlalchemy的常用數(shù)據(jù)類型有哪些

    這篇文章主要介紹了解讀sqlalchemy的常用數(shù)據(jù)類型有哪些,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • python實現(xiàn)圖像隨機裁剪的示例代碼

    python實現(xiàn)圖像隨機裁剪的示例代碼

    這篇文章主要介紹了python實現(xiàn)圖像隨機裁剪的示例代碼,幫助大家更好的理解和使用python處理圖片,感興趣的朋友可以了解下
    2020-12-12
  • Python使用RPC例子

    Python使用RPC例子

    本文主要介紹了Python使用RPC例子,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Python 列表映射后的平均值

    Python 列表映射后的平均值

    這篇文章主要介紹了Python 列表映射后的平均值,下面文章將圍繞Python 列表映射后的平均值得相關(guān)資料展開詳細內(nèi)容,需要的朋友可以參考一下
    2021-11-11
  • python進度條顯示-tqmd模塊的實現(xiàn)示例

    python進度條顯示-tqmd模塊的實現(xiàn)示例

    這篇文章主要介紹了python進度條顯示-tqmd模塊的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • python之django母板頁面的使用

    python之django母板頁面的使用

    這篇文章主要介紹了python之django母板頁面的使用,母版頁用于處理html頁面相同部分內(nèi)容,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 常見python正則用法的簡單實例

    常見python正則用法的簡單實例

    下面小編就為大家?guī)硪黄R妏ython正則用法的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • python logging.info在終端沒輸出的解決

    python logging.info在終端沒輸出的解決

    這篇文章主要介紹了python logging.info在終端沒輸出的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • 解決python 文本過濾和清理問題

    解決python 文本過濾和清理問題

    文本過濾和清理所涵蓋的范圍非常廣泛,涉及文本解析和數(shù)據(jù)處理方面的問題。這篇文章主要介紹了解決python 文本過濾和清理問題,需要的朋友可以參考下
    2019-08-08
  • Python實現(xiàn)?MK檢驗示例代碼

    Python實現(xiàn)?MK檢驗示例代碼

    這篇文章主要介紹了Python實現(xiàn)?MK檢驗,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12

最新評論