gpt4 book ai didi

python - 使用 pygtk 运行多个进程并捕获 python 中的输出

转载 作者:行者123 更新时间:2023-12-01 06:19:51 26 4
gpt4 key购买 nike

我想编写一个简单的应用程序,它运行多个程序并在多个终端(样式)窗口中显示它们的输出。此外,我希望能够读取这些进程的 stdout/stderr 并在输出中搜索关键字。

我尝试在 python 中实现这两种方式,第一种使用 subprocess.Popen,第二种使用 vte (python-vte)。

我只让 Popen 能够进行轮询。我必须不断检查进程是否有数据要读取,读取数据,然后将其发送到我的 TextArea。建议使用 gobject.io_add_watch() 来代替,但每当我尝试我的程序在第二次调用 io_add_watch 时挂起——就好像它一次只能处理一个文件描述符。

vte 效果很好,但我还没有找到可靠的方法来捕获输出。当光标移动时,您可以获得回调,然后使用 get_text() 进行屏幕抓取,但我已经遇到过这样的情况:我正在查看的这些程序一次性生成了 tty 的下流内容,然后它就离开了屏幕。似乎没有包含要添加到窗口的新文本的回调。

有什么想法吗?

最佳答案

我使用 subprocess.Popen 做了类似的事情。对于每个进程,我实际上最终将 stdout 和 stderr 重定向到临时文件,然后定期检查文件是否有更新并将输出转储到 TextView 中。 。

不使用管道连接进程的原因是进程本身是不稳定的并且容易出现段错误。发生这种情况时,我有时会丢失上次读取和段错误之间的数据(这是确定段错误原因最需要的数据)。

事实证明,有时我想保存特定进程的输出,所以这种方法对我来说效果很好。

关于python - 使用 pygtk 运行多个进程并捕获 python 中的输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/896874/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com