Gavin_Stargazer 2021-09-10 15:01 采纳率: 62.5%
浏览 39
已结题

【python】【装饰器】用于测量运行时长的装饰器,可以测量整个类,但不能测量类下属的函数

一、目标
用指定装饰器,测量类以及这个类下每个函数的的运行时长。
1、返回【class Main】的时长;
2、返回【def data】的时长;
3、返回【def save】的时长。
二、问题
现有代码可测量整个类的用时,但用于函数时会报错。
三、请帮助
如何修改才能实现上述目标?修改代码或提供思路均可,谢谢。

import time
import pandas as pd
import numpy as np

# 一、目标
#   用指定装饰器,测量类以及这个类下每个函数的的运行时长。
#   1、返回【class Main】的时长;
#   2、返回【def data】的时长;
#   3、返回【def save】的时长。
# 二、问题
#   现有代码可测量整个类的用时,但用于函数时会报错。
# 三、请帮助
#   如何修改才能实现上述目标?修改代码或提供思路均可,谢谢。


class Time_it:  # 一定要用类编写装饰器
    def __call__(self, func):
        def wrapper(*args, **kwargs):
            star = time.time()
            func(*args, **kwargs)
            end = time.time()
            print("【{}】运行时长: {}".format(func.__name__, end - star))

        return wrapper


@Time_it()  # 可以正常测量整个类的运行时长
class Main:
    def __init__(self):
        self.file = "test.xlsx"
        self.save()

    # @Time_it()#如果运行,则报错
    def data(self):
        dataframe = pd.DataFrame(np.random.randint(0, 100, size=(5, 3)))
        return dataframe

    # @Time_it()#如果运行,则报错
    def save(self):
        df = self.data()
        df.to_excel(self.file)


Main()

  • 写回答

2条回答 默认 最新

  • python收藏家 2021-09-10 15:49
    关注
    
    # 一、目标
    #   用指定装饰器,测量类以及这个类下每个函数的的运行时长。
    #   1、返回【class Main】的时长;
    #   2、返回【def data】的时长;
    #   3、返回【def save】的时长。
    # 二、问题
    #   现有代码可测量整个类的用时,但用于函数时会报错。
    # 三、请帮助
    #   如何修改才能实现上述目标?修改代码或提供思路均可,谢谢。
     
    class Time_it:  # 一定要用类编写装饰器
        def __call__(self, func):
            def wrapper(*args, **kwargs):
                star = time.time()
                func(*args, **kwargs)
                end = time.time()
                print("【{}】运行时长: {}".format(func.__name__, end - star))
            return wrapper
        
        @classmethod
        def time_data(cls,func):
            def wrapper(*args, **kwargs):
                star = time.time()
                res = func(*args, **kwargs)
                end = time.time()
                print("【{}】运行时长: {}".format(func.__name__, end - star))
                return res
            return wrapper
        
        @classmethod
        def time_save(cls,func):
            def wrapper(*args, **kwargs):
                star = time.time()
                func(*args, **kwargs)
                end = time.time()
                print("【{}】运行时长: {}".format(func.__name__, end - star))
            return wrapper
            
     
    @Time_it()  # 可以正常测量整个类的运行时长
    class Main:
        def __init__(self):
            self.file = "test.xlsx"
            self.save()
            
        @Time_it.time_data #如果运行,则报错
        def data(self):
            dataframe = pd.DataFrame(np.random.randint(0, 100, size=(5, 3)))
            return dataframe
        @Time_it.time_save #如果运行,则报错
        def save(self):
            df = self.data()
            df.to_excel(self.file)
     
    Main()
     
    
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 9月10日
  • 创建了问题 9月10日

悬赏问题

  • ¥15 Coze智能助手搭建过程中的问题请教
  • ¥15 12864只亮屏 不显示汉字
  • ¥20 三极管1000倍放大电路
  • ¥15 vscode报错如何解决
  • ¥15 前端vue CryptoJS Aes CBC加密后端java解密
  • ¥15 python随机森林对两个excel表格读取,shap报错
  • ¥15 基于STM32心率血氧监测(OLED显示)相关代码运行成功后烧录成功OLED显示屏不显示的原因是什么
  • ¥100 X轴为分离变量(因子变量),如何控制X轴每个分类变量的长度。
  • ¥30 求给定范围的全体素数p的(p-2)/p的连乘积值
  • ¥15 VFP如何使用阿里TTS实现文字转语音?