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

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

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

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
相关推荐
smile_Iris几秒前
Day 30 函数定义与参数
开发语言·python
冬-梦3 分钟前
Claude-Flow
ai·swarm·multi agent·claude code·claude-flow·hive-mind
杨航 AI7 分钟前
FORCE_VERIFYING_SIGNATURE=false
python
qq_3482318515 分钟前
如何搭建AI知识库
人工智能
thinkMoreAndDoMore17 分钟前
linux系统服务管理框架
linux·运维·服务器
AI弟18 分钟前
推荐系统:带你走进推荐之路(二)
人工智能·python·深度学习·面试·推荐算法
Julian.zhou21 分钟前
AI架构新范式:告别“短期记忆”,迎接能思考、会规划的智能体时代
人工智能·ai·架构·未来趋势
谈笑也风生21 分钟前
浅谈:被称为新基建的区块链(六)
人工智能·区块链
新华经济29 分钟前
正荣激光焊接机:破解中小型制造场景激光焊接精度与效率困局
大数据·人工智能·制造
waves浪游32 分钟前
进程控制(中)
linux·运维·服务器·开发语言·c++