【python】 日志打印、垃圾回收

log_utils 打印日志

报错截图

修改后,如下:

python 复制代码
import os  # 新增:用于路径处理

from functools import wraps
import time
import gc  # 新增

# 兼容CuPy/NumPy
try:
    import cupy as xp
except ImportError:
    import numpy as xp


def format_value(val):
    # 1. 处理CuPy/NumPy数组
    if isinstance(val, xp.ndarray):
        # 计算大小
        size_mb = val.nbytes / (1024 ** 2)

        # 关键修改:大数组不切片!
        if size_mb > 100:  # >100MB
            return f"ndarray(dtype={val.dtype}, shape={val.shape}) <{size_mb:.0f}MB>"
        elif val.ndim >= 2:
            return f"ndarray(dtype={val.dtype}, shape={val.shape})"
        else:
            val_str = str(val[:3]).replace('\n', '')
            return f"ndarray(dtype={val.dtype}, shape={val.shape}, val={val_str})"

    # 2. 处理纯数字
    elif isinstance(val, (int, float, complex)):
        return f"{type(val).__name__}({val})"

    # 3. 处理列表/元组
    elif isinstance(val, (list, tuple)):
        formatted_items = [format_value(item) for item in val[:2]]
        return f"{type(val).__name__}(len={len(val)}, items={formatted_items})"

    # 4. 其他类型
    else:
        return f"{type(val).__name__}({str(val)[:50]})"


def auto_log(func):
    @wraps(func)
    def wrapper(*args, **kwargs):
        func_name = func.__name__
        start_time = time.strftime('%H:%M:%S')

        # 关键:执行前清理内存
        gc.collect()

        # 格式化入参
        formatted_args = [format_value(arg) for arg in args]
        formatted_kwargs = {k: format_value(v) for k, v in kwargs.items()}

        # 打印开始日志
        print(f"\n[{start_time}] 🚀 {func_name} - 开始执行")
        print(f"   → 入参(args):{formatted_args}")
        print(f"   → 入参(kwargs):{formatted_kwargs}")

        # 执行原方法
        result = func(*args, **kwargs)

        # 格式化返回值
        formatted_result = format_value(result)
        end_time = time.strftime('%H:%M:%S')

        # 打印结束日志
        print(f"[{end_time}] ✅ {func_name} - 完成执行")
        print(f"   → 返回值:{formatted_result}")

        # 关键:执行后清理内存
        gc.collect()

        return result

    return wrapper
相关推荐
郭涤生11 分钟前
不同主机之间网络通信-以太网连接复习
开发语言·rk3588
山居秋暝LS16 分钟前
【无标题】RTX00安装paddle OCR,win11不能装最新的,也不能用GPU
开发语言·r语言
卢锡荣20 分钟前
单芯通吃,盲插标杆 —— 乐得瑞 LDR6020,Type‑C 全场景互联 “智慧芯”
c语言·开发语言·计算机外设
Xin_ye1008625 分钟前
C# 零基础到精通教程 - 第七章:面向对象编程(入门)——类与对象
开发语言·c#
彦为君41 分钟前
Agent 安全:从权限提示到沙箱隔离
python·ai·ai编程
AI科技星1 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
审判长烧鸡1 小时前
【Go工具】go-playground是什么组织?官方的?
开发语言·安全·go
PILIPALAPENG1 小时前
Python 语法速成指南:前端开发者视角(JS 类比版)
前端·人工智能·python
kkeeper~1 小时前
0基础C语言积跬步之字符函数与字符串函数(上)
c语言·开发语言
hhb_6182 小时前
Swift核心技术难点与实战案例解析
开发语言·ios·swift