中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

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

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

加格達(dá)奇網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),加格達(dá)奇網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為加格達(dá)奇超過千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的加格達(dá)奇做網(wǎng)站的公司定做!

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

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

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

實(shí)例

import importlib
import sys
from functools import wraps
 
 
def func_wrapper(func):
    """這里通過一個裝飾器來達(dá)到貍貓換太子和獲取數(shù)據(jù)的效果"""
    @wraps(func)
    def wrapper(*args, **kwargs):
        # 記錄開始時間
        start = time.time()
        result = func(*args, **kwargs)
        # 統(tǒng)計消耗時間
        end = time.time()
        print(f"speed time:{end - start}")
        return result
    return wrapper
 
 
class MetaPathFinder:
 
    def find_module(self, fullname, path=None):
        # 執(zhí)行時可以看出來在import哪些模塊
        print(f'find module:{path}:{fullname}')
        return MetaPathLoader()
 
 
class MetaPathLoader:
 
    def load_module(self, fullname):
        # import的模塊都會存放在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)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

當(dāng)前標(biāo)題:python探針怎么實(shí)現(xiàn)
當(dāng)前URL:http://www.rwnh.cn/article40/gopcho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、云服務(wù)器、外貿(mào)建站Google、服務(wù)器托管網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
广平县| 延安市| 丘北县| 高安市| 灵石县| 萍乡市| 会昌县| 田林县| 博乐市| 青浦区| 太仓市| 津市市| 安塞县| 绥芬河市| 海城市| 孝感市| 类乌齐县| 隆回县| 沽源县| 博爱县| 阿尔山市| 剑阁县| 龙里县| 潼关县| 宜城市| 宣武区| 商城县| 微博| 大关县| 南澳县| 茶陵县| 凌云县| 荔浦县| 广平县| 定西市| 宁津县| 沙洋县| 龙江县| 双牌县| 保定市| 阳新县|