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

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

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

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
相关推荐
和平宇宙2 分钟前
AI笔记001. temperature top_p到底是什么,为什么top_p都是0.95,不设置成1
人工智能·笔记
程序员三藏3 分钟前
如何用Selenium实现自动化?
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
JicasdC123asd3 分钟前
Converse2D频域卷积上采样改进YOLOv26图像重建与细节恢复能力
人工智能·yolo·目标跟踪
云和数据.ChenGuang5 分钟前
chromadb为什么需要模拟数据运行
人工智能·神经网络·目标检测·机器学习·计算机视觉
2301_793804696 分钟前
如何从Python初学者进阶为专家?
jvm·数据库·python
m0_518019486 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
freewlt6 分钟前
OpenClaw开发者深度指南:如何构建可扩展的AI助手生态系统
人工智能·openclaw
bitbrowser6 分钟前
如何仿真拟人输入,避免被ai检测成机器人?
人工智能·机器人
秦始皇爱找茬6 分钟前
Claude Code 文件层级机制详解
人工智能·codex·claude code·open code
wapicn997 分钟前
智能识别技术在生活服务领域的落地应用与前景展望
java·c++·人工智能·python·php