溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python探針怎么實(shí)現(xiàn)

發(fā)布時(shí)間:2021-09-07 11:00:39 來源:億速云 閱讀:118 作者:小新 欄目:編程語言

這篇文章將為大家詳細(xì)講解有關(guān)python探針怎么實(shí)現(xiàn),小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

1、探針importhook的功能可以通過sys.meta_path來實(shí)現(xiàn)。

2、當(dāng)執(zhí)行import相關(guān)操作時(shí),import相關(guān)庫將根據(jù)sys.meta_path定義的對(duì)象進(jìn)行更改。

sys.meta_path中的對(duì)象需要實(shí)現(xiàn)find_module方法。這種find_module方法返回None或?qū)崿F(xiàn)load_module方法的對(duì)象。我們可以通過這個(gè)對(duì)象在import中替換一些圖書館的相關(guān)方法。簡單用法如下。通過hooktime.sleep,可以在sleep中打印時(shí)間。

實(shí)例

import importlib
import sys
from functools import wraps
 
 
def func_wrapper(func):
    """這里通過一個(gè)裝飾器來達(dá)到貍貓換太子和獲取數(shù)據(jù)的效果"""
    @wraps(func)
    def wrapper(*args, **kwargs):
        # 記錄開始時(shí)間
        start = time.time()
        result = func(*args, **kwargs)
        # 統(tǒng)計(jì)消耗時(shí)間
        end = time.time()
        print(f"speed time:{end - start}")
        return result
    return wrapper
 
 
class MetaPathFinder:
 
    def find_module(self, fullname, path=None):
        # 執(zhí)行時(shí)可以看出來在import哪些模塊
        print(f'find module:{path}:{fullname}')
        return MetaPathLoader()
 
 
class MetaPathLoader:
 
    def load_module(self, fullname):
        # import的模塊都會(huì)存放在sys.modules里面, 通過判斷可以減少重復(fù)import
        if fullname in sys.modules:
            return sys.modules[fullname]
        # 防止遞歸調(diào)用
        finder = sys.meta_path.pop(0)
        # 導(dǎo)入 module
        module = importlib.import_module(fullname)
        if fullname == 'time':
            # 替換函數(shù)
            module.sleep = func_wrapper(module.sleep)
        sys.meta_path.insert(0, finder)
        return module
 
 
sys.meta_path.insert(0, MetaPathFinder())
 
 
if __name__ == '__main__':
    import time
    time.sleep(1)
 
 
# 輸出示例:
# find module:datetime
# find module:time
# load module:time
# find module:math
# find module:_datetime
# speed time:1.00073385238647468

關(guān)于“python探針怎么實(shí)現(xiàn)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI