Python模块声明有关沟通()函数:
备注 数据读取是在内存中缓冲的,所以如果数据大小是大的或无限的,就不要使用这种方法。
如何执行读取大量数据的进程(例如通信()被禁止),但仍然可以访问stderr输出?
发布于 2014-04-24 20:34:37
若要在子进程的stdout/stderr输出可用时单独获得可能无限的子进程输出,可以使用spawnProcess()
#!/usr/bin/env python
from twisted.internet import protocol
from twisted.internet import reactor
class ProcessProtocol(protocol.ProcessProtocol):
def outReceived(self, data):
print 'got stdout:', data
def errReceived(self, data):
print 'got stderr:', data
def processEnded(self, reason):
reactor.stop()
process = ProcessProtocol()
reactor.spawnProcess(process, 'cmd', ['cmd', 'arg 1', 'arg 2'])
reactor.run()
另一种选择是使用线程(例如,teed_call()
)或使用特定于操作系统的代码(例如,POSIX系统上的模块,使管道无阻塞。 )或使用Windows上与命名管道的重叠I/O。
发布于 2014-04-24 07:46:22
"communicate()“通过使用线程解决了这个问题。这意味着,在执行主线程中的主要工作(读取stdout)时,需要额外的stderr读取线程。或者,您可以使用select.select,但这不适用于windows。
发布于 2014-04-24 07:56:13
根据您的问题类型,您可以重新排列代码,以便将stderr
进程输送到您的python代码中。此页有一些提示。
https://stackoverflow.com/questions/23262455
复制相似问题