使用装饰器实现自动化日志系统

使用装饰器实现自动化日志系统

使用装饰器实现自动化日志系统的示例代码如下:

python 复制代码
import logging
from functools import wraps

def log_function(func):
    @wraps(func)
    def wrapper(*args, **kwargs):
        logging.info(f"调用函数:{func.__name__}")
        result = func(*args, **kwargs)
        logging.info(f"函数执行完成:{func.__name__},结果为:{result}")
        return result
    return wrapper

@log_function
def 加法(a, b):
    return a + b

@log_function
def 乘法(a, b):
    return a * b

logging.basicConfig(level=logging.INFO)

print(加法(2, 3))
print(乘法(4, 5))

在这个示例中,我们定义了一个装饰器 log_function,它记录函数调用前的和后的信息。@wraps(func) 用于保留原始函数的元数据(名称、文档字符串等)。

然后,我们将这个装饰器应用于两个函数:加法乘法。当这些函数被调用时,它们将被包围在 logging 函数中。

输出结果将是:

python 复制代码
INFO:root:调用函数:加法
INFO:root:函数执行完成:加法,结果为:5
INFO:root:调用函数:乘法
INFO:root:函数执行完成:乘法,结果为:20
相关推荐
行初心1 分钟前
uos基础 ps 查看进程
运维
新智元4 分钟前
GPT-5.1发布当天,文心5.0杀回来了
人工智能·openai
月下倩影时16 分钟前
视觉学习篇——机器学习模型评价指标
人工智能·学习·机器学习
领航猿1号19 分钟前
如何通过神经网络看模型参数量?
人工智能·python·神经网络·大模型参数量
mywpython19 分钟前
Python使用消息队列rabbitmq
开发语言·python·rabbitmq
大囚长22 分钟前
神经网络AI在人类发明史上的独特性
人工智能·深度学习·神经网络
嵌入式-老费26 分钟前
自己动手写深度学习框架(数值法实现神经网络的训练)
人工智能·深度学习·神经网络
Learn Beyond Limits28 分钟前
Regression vs. Classification|回归vs分类
人工智能·python·算法·ai·分类·数据挖掘·回归
mayubins36 分钟前
稳定边界层高度参数化方案的回归建模
人工智能·数据挖掘·回归
不去幼儿园39 分钟前
【强化学习】可证明安全强化学习(Provably Safe RL)算法详细介绍
人工智能·python·算法·安全·机器学习·强化学习