首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >显示包装函数的调用位置- loguru

显示包装函数的调用位置- loguru
EN

Stack Overflow用户
提问于 2020-07-15 21:16:00
回答 1查看 225关注 0票数 1

我想记录我的应用程序发送的所有请求(requests.get、requests.post等)。为了不使用样板,我决定将函数包装在requests模块中:

代码语言:javascript
复制
import functools

from loguru import logger
import requests

def logging_wrap(foo):
    @functools.wraps(foo)
    def _(*args, **kwargs):
        logger.debug(f"Calling {foo.__name__} with args {args} and kwargs {kwargs}")
        return foo(*args, **kwargs)

    return _

requests.get = logging_wrap(requests.get)

requests.get("https://google.com")

问题是日志引用的是包装器(logger.debug)中的点,而不是requests.get被调用的位置。如何使loguru显示正确的调用位置?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-27 16:58:49

多亏了depth参数,您可以使用专门为处理包装函数的情况而设计的opt()方法:

代码语言:javascript
复制
logger.opt(depth=1).debug(f"Calling {foo.__name__} with args {args} and kwargs {kwargs}")
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62915770

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档