Is there a way in Python to do the equivalent of the UNIX command line tee? I’m doing a typical fork/exec pattern, and I’d like the stdout from the child to appear in both a log file and on the stdout of the parent simultaneously without requiring any buffering.
In this python code for instance, the stdout of the child ends up in the log file, but not in the stdout of the parent.
pid = os.fork()
logFile = open(path,"w")
if pid == 0:
os.dup2(logFile.fileno(),1)
os.execv(cmd)
edit: I do not wish to use the subprocess module. I’m doing some complicated stuff with the child process that requires me call fork manually.
Here you have a working solution without using the
subprocessmodule. Although, you could use it for the tee process while still using theexec*functions suite for your custom subprocess (just usestdin=subprocess.PIPEand then duplicate the descriptor to your stdout).Note that the
teecommand, internally, does the same thing as Ben suggested in his answer: reading input and looping over output file descriptors while writing to them. It may be more efficient because of the optimized implementation and because it’s written in C, but you have the overhead of the different pipes (don’t know for sure which solution is more efficient, but in my opinion, reassigning a custom file-like object tostdoutis a more elegant solution).Some more resources: