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

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

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

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
相关推荐
jkyy2014几秒前
破局家电同质化:智能冰箱+主动健康,解锁家庭健康新赛道
大数据·人工智能·健康医疗
王知无(import_bigdata)5 分钟前
一个极简的AI Agentic Engineering技术栈学习路线
人工智能·学习
white.tie10 分钟前
scrapling AI爬虫 初体验
爬虫·ai
ToB营销学堂12 分钟前
B2B AI内容实战指南:AI提效 x GEO获客 x 增长闭环
人工智能·geo·b2b营销获客
gutsyang15 分钟前
LLM -> Agent -> Claw -> ? | “后 GUI 时代”的终局预测
ai·ai作画·ai编程·ai写作
东离与糖宝23 分钟前
Java 玩转 AI 智能体性能优化:OpenClaw 高并发调用与 Token 成本控制实战
java·人工智能
芯片-嵌入式29 分钟前
具身智能(3):有哪些AI模型
人工智能·深度学习·机器学习
skywalk816330 分钟前
在LMStudio中使用microsoft_Fara-7B 模型(未实践)
人工智能·microsoft
cxr82832 分钟前
创建专业虚拟一人公司的 Skills 深度对比分析
人工智能·ai智能体·openclaw
糟糕喔42 分钟前
harbor私有仓库搭建
运维·docker·云原生·容器·kubernetes