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

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

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

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
相关推荐
张较瘦_6 分钟前
[论文阅读] AI+软件工程(DeBug)| 从11%到53%!双LLM驱动的工业级代码修复方案,Google数据集验证有效
论文阅读·人工智能·软件工程
qq_4026056510 分钟前
python爬虫(三) ---- 分页抓取数据
开发语言·爬虫·python
唐叔在学习10 分钟前
Pywebview:Web技术构建桌面应用的最佳选择
后端·python·webview
ZLRRLZ15 分钟前
【Linux操作系统】进程概念
linux·运维·服务器
我是Feri22 分钟前
机器学习之线性回归下的数据预处理:数据清洗的艺术(食材筛选指南)
开发语言·python·机器学习
奔跑的石头_34 分钟前
GPT-5最新特性和优点
人工智能
卷Java41 分钟前
预约记录关联查询接口说明
java·开发语言·spring boot·python·微信小程序
MPCTHU42 分钟前
Deep Learning|01 RBF Network
人工智能·深度学习
wa的一声哭了43 分钟前
Deep Learning Optimizer | Adam、AdamW
人工智能·深度学习·神经网络·机器学习·自然语言处理·transformer·pytest
晨曦54321044 分钟前
机器学习完整流程详解
人工智能·机器学习