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

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

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

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
相关推荐
风吹稻香飘几秒前
【无标题】
人工智能·ai
Mintopia几秒前
🤖 AIGC技术对Web行业就业结构的影响:替代与新增岗位分析
人工智能·llm·aigc
共绩算力2 分钟前
给 TRAE SOLO 一台服务器,它能干什么?
运维·服务器
databook3 分钟前
数据点的“社交距离”:衡量它们之间的相似与差异
python·数据挖掘·数据分析
wei_shuo5 分钟前
Mamba LLM 架构简介:机器学习的新范式
人工智能·机器学习·架构
DKunYu9 分钟前
3.负载均衡-LoadBalance
java·运维·spring cloud·微服务·负载均衡
keineahnung23459 分钟前
PyTorch動態形狀系統的基石 - SymNode
人工智能·pytorch·python·深度学习
AwakeFantasy9 分钟前
关于最近想做一个基于日k选股票的系统这件事
python·股票·量化
2401_8315017312 分钟前
Devops之Docker安装和使用
运维·docker·devops
昔时扬尘处13 分钟前
如何检测python和pytest的安装环境
开发语言·python·pytest·自动化测试平台·adi