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

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

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

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
相关推荐
木卫二号Coding1 分钟前
第五十三篇-Ollama+V100+Qwen3:4B-性能
人工智能
飞哥数智坊3 分钟前
AI 不只是聊天:聊聊我最近在做的新方向
人工智能
Q_Q51100828510 分钟前
python+django/flask+vue的大健康养老公寓管理系统
spring boot·python·django·flask·node.js
我是哈哈hh25 分钟前
【Python数据分析】Numpy总结
开发语言·python·数据挖掘·数据分析·numpy·python数据分析
Michelle802326 分钟前
24大数据 14-2 函数练习
开发语言·python
qq_3814549929 分钟前
Python学习技巧
开发语言·python·学习
学生高德30 分钟前
小模型结合大模型的加速方法关键笔记
人工智能·深度学习·机器学习
Ndmzi35 分钟前
Matlab编程技巧:自定义Simulink菜单(理解补充)
前端·javascript·python
蓝耘智算37 分钟前
GPU算力租赁与算力云平台选型指南:从需求匹配到成本优化的实战思路
大数据·人工智能·ai·gpu算力·蓝耘
aLong@201638 分钟前
iflow通过hooks增加提醒
ai·aigc·agi