通过子进程捕获输出,但不使用COMPLICATE

Capture output via subprocess w/o using communicate(通过子进程捕获输出,但不使用COMPLICATE)
本文介绍了通过子进程捕获输出,但不使用COMPLICATE的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用子进程在Python脚本中调用外部程序。外部程序产生了大量的输出。我需要捕获该程序的输出。当前代码如下所示:

process = subprocess.Popen('cmd.exe', shell=False, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=None)
process.stdin.write('gams "indus89.gms"
')
while process.poll() != None:
    line = process.stdout.readline()
    print line

我在此代码中收到的错误是

进程试图写入不存在的管道。

如果我使用以下代码:

process = subprocess.Popen('cmd.exe', shell=False, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=None)
process.stdin.write('gams "indus89.gms"
')
o, e = process.communicate()
print o 

则不捕获程序的输出。

我应该如何更改代码,以便可以在第三方程序运行时捕获其输出?

推荐答案

打开有点矫枉过正。

尝试:

output = subprocess.check_output('gams "indus89.gms"
', shell=True)

希望这能在您的环境中发挥作用。

这篇关于通过子进程捕获输出,但不使用COMPLICATE的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)