performance_stats.py 2.09 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import time
import functools
from collections import defaultdict
from typing import Dict, List


class PerformanceStats:
    """性能统计类,用于收集和展示方法执行时间"""

    _stats: Dict[str, List[float]] = defaultdict(list)

    @classmethod
    def add_execution_time(cls, func_name: str, execution_time: float):
        """添加执行时间记录"""
        cls._stats[func_name].append(execution_time)

    @classmethod
    def get_stats(cls) -> Dict[str, dict]:
        """获取统计结果"""
        results = {}
        for func_name, times in cls._stats.items():
            results[func_name] = {
                'count': len(times),
                'total_time': sum(times),
                'avg_time': sum(times) / len(times),
                'min_time': min(times),
                'max_time': max(times)
            }
        return results

    @classmethod
    def print_stats(cls):
        """打印统计结果"""
        stats = cls.get_stats()
        print("\n性能统计结果:")
        print("-" * 80)
        print(f"{'方法名':<40} {'调用次数':>8} {'总时间(s)':>12} {'平均时间(s)':>12}")
        print("-" * 80)
        for func_name, data in stats.items():
            print(f"{func_name:<40} {data['count']:8d} {data['total_time']:12.6f} {data['avg_time']:12.6f}")


def measure_time(func):
    """测量方法执行时间的装饰器"""

    @functools.wraps(func)
    def wrapper(*args, **kwargs):
        start_time = time.time()
        result = func(*args, **kwargs)
        execution_time = time.time() - start_time
51
52
53
54
55
56
57
58
59
60
61
62

        # 获取更详细的函数标识
        if hasattr(func, "__self__"):  # 实例方法
            class_name = func.__self__.__class__.__name__
            full_name = f"{class_name}.{func.__name__}"
        elif hasattr(func, "__qualname__"):  # 类方法或静态方法
            full_name = func.__qualname__
        else:
            module_name = func.__module__
            full_name = f"{module_name}.{func.__name__}"

        PerformanceStats.add_execution_time(full_name, execution_time)
63
64
65
        return result

    return wrapper