Day31 函数专题2

@浙大疏锦行

作业:编写一个装饰器logger,在函数执行前后打印日志信息

python 复制代码
# 导入必要模块,functools.wraps用于保留被装饰函数的元信息
import functools
from datetime import datetime

def logger(func):
    """
    日志装饰器:在函数执行前后打印相关日志信息
    :param func: 被装饰的函数
    :return: 包装后的函数
    """
    # 使用functools.wraps装饰内层函数,保留原函数的__name__、__doc__等元信息
    @functools.wraps(func)
    def wrapper(*args, **kwargs):
        """内层包装函数,实现日志打印逻辑"""
        # 1. 函数执行前:打印前置日志
        func_name = func.__name__  # 获取原函数名
        current_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")  # 获取当前格式化时间
        print(f"[{current_time}] 开始执行函数:{func_name}()")
        print(f"[{current_time}] 函数{func_name}的位置参数:{args}")
        print(f"[{current_time}] 函数{func_name}的关键字参数:{kwargs}")
        
        # 2. 执行原函数,保存返回值(兼容有返回值的函数)
        try:
            result = func(*args, **kwargs)
        except Exception as e:
            # 捕获函数执行异常并打印
            print(f"[{current_time}] 函数{func_name}执行失败,异常信息:{str(e)}")
            raise  # 重新抛出异常,不影响原函数的异常传播
        else:
            # 3. 函数执行成功后:打印后置日志
            print(f"[{current_time}] 函数{func_name}执行完成,返回结果:{result}")
            return result  # 返回原函数的执行结果
    
    return wrapper
相关推荐
金銀銅鐵2 小时前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li4 小时前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸9 小时前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学10 小时前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
花酒锄作田1 天前
Pydantic校验配置文件
python
hboot1 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi2 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽2 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187912 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python