在Python中使用curses进行日志记录

发布于 2024-12-28 13:30:16 字数 124 浏览 0 评论 0原文

我正在与日志记录模块一起使用诅咒,并且在启动诅咒时遇到日志记录问题。

日志记录正在工作,并将一些文本打印到控制台(取决于级别),直到调用curses.initscr() 。

关于如何修复它有什么想法吗?

I am using curses alongside the logging module and I'm having a problem with logging when curses is started.

Logging is working and prints some text to console (depending on the level) until curses.initscr() is called.

Any idea on how to fix it?

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

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

发布评论

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

评论(1

小清晰的声音 2025-01-04 13:30:16

一旦curses被初始化,你应该通过它执行所有输出 - 否则它会看起来很愚蠢(正如你所看到的)。

您不能只使用 print/sys.(stdout|stderr).write,因为它会干扰 ncurses 输出。

最好的解决方案是,制作一个 ncurses pad 用于日志记录,将所有日志消息重定向到它。您可以自定义日志处理程序来执行此操作(请查看 logging.handlers以获得一些灵感)。

Once curses is initialized, you should perform all output through it - otherwise it'll look goofy (as you're seeing).

You can't just use print/sys.(stdout|stderr).write, as it'll interfere with ncurses output.

Best solution would be, make an ncurses pad to use for logging, redirect all log messages to it. You can customize your logging handler to do this (take a look at logging.handlers for some inspiration).

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