在python中,将日志记录和ncurses转到单独的TTY
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了在python中,将日志记录和ncurses转到单独的TTY,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1587字,纯文字阅读大概需要3分钟。
内容图文
![在python中,将日志记录和ncurses转到单独的TTY](/upload/InfoBanner/zyjiaocheng/667/b5ba817fc19a4eaaa3e9c49ebd4358b5.jpg)
我已经编写了一个充当服务器(tcp,kindof)的python程序,并在stdout(和文件)上记录了大量重要信息.该程序在ARM板上运行,并附有少量VGA显示.
现在,我想在板子的物理显示屏上显示一些信息,同时保持启动程序所在的tty的日志记录.
假设我通过SSH连接到ARM板,然后在/ dev / tty3上运行该程序.
我设法使用ncurses在/ dev / tty1(这是物理显示)上显示内容.问题是,所有日志记录也都将显示在物理显示器上.
为了实现这一点,我基本上使用在SO上找到的一些代码将stodut重定向到/ dev / tty1:
NCURSES_TTY = '/dev/tty1'
with open(NCURSES_TTY, 'rb') as inf, open(NCURSES_TTY, 'wb') as outf:
os.dup2(inf.fileno(), 0)
os.dup2(outf.fileno(), 1)
os.dup2(outf.fileno(), 2)
os.environ['TERM'] = 'linux'
logging.debug("Starting server..")
但这当然会重定向所有输出.关于如何将ncurses和普通python日志记录拆分为单独的TTY的任何想法?
解决方法:
好,解决了..这很简单..
1)检测当前的tty
import os
import sys
tty=os.ttyname(sys.stdout.fileno())
2)设置python loggin以记录到检测到的tty
import logging
logger = logging.getLogger(__package__)
logger.setLevel(log_level)
# console_handler = logging.StreamHandler()
console_handler = logging.FileHandler(tty)
console_handler.setLevel(logging.DEBUG)
logger.addHandler(console_handler)
3)欺骗stdout和err去想要的tty
NCURSES_TTY = '/dev/tty1'
with open(NCURSES_TTY, 'rb') as inf, open(NCURSES_TTY, 'wb') as outf:
os.dup2(inf.fileno(), 0)
os.dup2(outf.fileno(), 1)
os.dup2(outf.fileno(), 2)
os.environ['TERM'] = 'linux'
4)导入ncurses并进行日志记录
import curses
stdscr = curses.initscr()
curses.noecho()
logging.debug("Tryout")
stdscr.addstr(0, 0, "Current mode: Paola mode",
curses.A_REVERSE)
stdscr.refresh()
而已. Unix的功能(在OSX上测试).
内容总结
以上是互联网集市为您收集整理的在python中,将日志记录和ncurses转到单独的TTY全部内容,希望文章能够帮你解决在python中,将日志记录和ncurses转到单独的TTY所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。