Python - 日志记录和级别

发布于 2024-11-09 00:15:43 字数 220 浏览 0 评论 0原文

我使用 python 模块 logging 来生成日志文件和控制台打印。 我将脚本设置为记录所有错误级别,而不将 DEBUG 写入文件。 但我在设置控制台打印处理程序时遇到问题。在控制台上,我想显示级别 INFObelow,而不是像 setLevel 那样显示级别。有什么方法可以使用内联代码来做到这一点吗?

I use python module logging to generate log files and console print.
I set up my script to log all errors levels, without DEBUG to file.
But i have trouble with set up handler for console printing. On console i want to display level INFO and below, not up like setLevel doing. Is any way to do this with inline code?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

回梦 2024-11-16 00:15:43

我不确定“内联代码”到底是什么意思,但您可以使用过滤器来实现这一点。

class InfoAndLower(logging.Filter):
    def filter(self, record):
        return record.levelno <= logging.INFO

然后将过滤器实例附加到控制台处理程序。

h = logging.StreamHandler(sys.stdout)
h.addFilter(InfoAndLower())

在 Python 3.2 及更高版本中,您不需要创建类 - 可调用即可:

h.addFilter(lambda record: record.levelno <= logging.INFO)

I'm not sure exactly what you mean by "inline code", but you can achieve this using Filters.

class InfoAndLower(logging.Filter):
    def filter(self, record):
        return record.levelno <= logging.INFO

and then attach a filter instance to your console handler.

h = logging.StreamHandler(sys.stdout)
h.addFilter(InfoAndLower())

In Python 3.2 and later, you don't need to create a class - a callable will do:

h.addFilter(lambda record: record.levelno <= logging.INFO)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文