亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

炉霍县| 正安县| 郸城县| 通江县| 灵璧县| 农安县| 蒙城县| 深泽县| 淄博市| 乡城县| 永济市| 三门峡市| 惠东县| 千阳县| 辽中县| 永修县| 泰安市| 黄冈市| 山东省| 卢湾区| 盘锦市| 奇台县| 武胜县| 珠海市| 准格尔旗| 通道| 金阳县| 集安市| 临武县| 苏尼特左旗| 永济市| 沅江市| 伊宁县| 满城县| 始兴县| 白水县| 盱眙县| 来凤县| 剑河县| 伊吾县| 天气|