91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python的探針怎么實現

發布時間:2022-05-23 16:54:25 來源:億速云 閱讀:130 作者:iii 欄目:大數據

這篇文章主要介紹“python的探針怎么實現”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“python的探針怎么實現”文章能幫助大家解決問題。

1、探針importhook的功能可以通過sys.meta_path來實現。

2、當執行import相關操作時,import相關庫將根據sys.meta_path定義的對象進行更改。

sys.meta_path中的對象需要實現find_module方法。這種find_module方法返回None或實現load_module方法的對象。我們可以通過這個對象在import中替換一些圖書館的相關方法。簡單用法如下。通過hooktime.sleep,可以在sleep中打印時間。

實例

import importlib
import sys
from functools import wraps
 
 
def func_wrapper(func):
    """這里通過一個裝飾器來達到貍貓換太子和獲取數據的效果"""
    @wraps(func)
    def wrapper(*args, **kwargs):
        # 記錄開始時間
        start = time.time()
        result = func(*args, **kwargs)
        # 統計消耗時間
        end = time.time()
        print(f"speed time:{end - start}")
        return result
    return wrapper
 
 
class MetaPathFinder:
 
    def find_module(self, fullname, path=None):
        # 執行時可以看出來在import哪些模塊
        print(f'find module:{path}:{fullname}')
        return MetaPathLoader()
 
 
class MetaPathLoader:
 
    def load_module(self, fullname):
        # import的模塊都會存放在sys.modules里面, 通過判斷可以減少重復import
        if fullname in sys.modules:
            return sys.modules[fullname]
        # 防止遞歸調用
        finder = sys.meta_path.pop(0)
        # 導入 module
        module = importlib.import_module(fullname)
        if fullname == 'time':
            # 替換函數
            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

關于“python的探針怎么實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黑龙江省| 衡山县| 孟连| 台北县| 大同市| 三原县| 高唐县| 泸溪县| 印江| 拜城县| 二连浩特市| 大田县| 冷水江市| 彝良县| 保定市| 伊金霍洛旗| 宜城市| 蕉岭县| 连城县| 玉龙| 孟州市| 日喀则市| 南汇区| 同心县| 灵璧县| 太和县| 谢通门县| 吴江市| 双桥区| 茂名市| 邮箱| 马边| 曲水县| 美姑县| 石首市| 旺苍县| 鄢陵县| 资兴市| 普陀区| 绥棱县| 石嘴山市|