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

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

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

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
相关推荐
f***68604 分钟前
问题:Flask应用中的用户会话(Session)管理失效
后端·python·flask
爱吃面条的猿9 分钟前
Python修改pip install 指定安装包的路径和默认镜像源
linux·python·pip
饭饭大王66611 分钟前
Python 模块的概念与导入:从基础语法到高级技巧
java·服务器·python
佐杰20 分钟前
Jenkins备份管理
java·运维·jenkins
杨云龙UP22 分钟前
【MySQL逻辑备份】基于mysqldump的MySQL 8.0全量逻辑备份脚本
linux·运维·数据库·sql·mysql·mssql
t***L26627 分钟前
GitLab API使用实例
运维·gitlab
roman_日积跬步-终至千里30 分钟前
【AI Engineering】Should I build this AI application?—AI应用决策框架与实践指南
大数据·人工智能
Sunhen_Qiletian31 分钟前
python语言应用实战--------网络爬虫篇 第二篇(selenium库)
爬虫·python·selenium
新智元36 分钟前
谷歌 Nano Banana Pro 炸了!硅谷 AI 半壁江山同框,网友:PS 已死
人工智能·openai
m***D28639 分钟前
机器学习总结
人工智能·机器学习