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

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

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

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 分钟前
深度学习基础原理:从理论到PyTorch实践
人工智能
蒲公英源码2 分钟前
AI智慧教育平台架构设计与实现方案,基于Jdk17+SpringBoot3AI智慧教育平台
java·人工智能·mysql·jdk
葡萄城技术团队7 分钟前
AI 重构数据分析:技术突破与价值释放
人工智能·重构·数据分析
慕ゞ笙8 分钟前
2025年Ubuntu24.04系统安装以及深度学习环境配置
人工智能·深度学习
jimmyleeee11 分钟前
人工智能基础知识笔记二十一:Function Calling
人工智能·笔记
量化Mike13 分钟前
【python报错】解决卸载Python时报错问题:No Python installation was detected
开发语言·python
丝斯201113 分钟前
AI学习笔记整理(21)—— AI核心技术(深度学习5)
人工智能·笔记·学习
鹿鸣天涯16 分钟前
使用VMware Workstation 17虚拟机安装红帽企业版系统RHEL10
linux·运维·服务器
SKYDROID云卓小助手18 分钟前
三轴云台之控制协同技术
服务器·网络·图像处理·人工智能·算法
2501_9417987325 分钟前
Python高性能网络爬虫实战:异步IO与多线程结合代码解析
开发语言·python