get text from rogramms runn by subprocess.Popen immediatetly

norseman norseman at hughes.net
Thu Apr 16 14:13:13 EDT 2009


Rüdiger Ranft wrote:
> Hi all,
> 
> I need to call some programms and catch their stdout and stderr streams.
> While the Popen class from subprocess handles the call, I get the
> results of the programm not until the programm finishes. Since the
> output of the programm is used to generate a progress indicator, I need
> a way to acces the values written to stdout/stderr as fast as possible.
> 
> Beneath is a test which shows what I did
> 
> TIA
> Rudi
> 
> ----8<-------8<-------8<-- iodummy.cpp -8<-------8<---
> #include <iostream>
> #include <unistd.h>
> 
> int main()
> {
>         for( int i = 0; i < 10; i++ )
>         {
>                 std::cerr << i << std::endl;
>                 sleep(2);
>         }
> }
> 
> from subprocess import Popen, PIPE
> from time import sleep
> 
> p = Popen('./iodummy',stdin=PIPE, stdout=PIPE, stderr=PIPE)
> sleep(3)
> # now I expect '0\n1\n' in stderr, but read() blocks until
> # the end of iodummy.
> print p.stderr.read()
> p.wait()
> 
> 
> 
> ------------------------------------------------------------------------
> 
> --
> http://mail.python.org/mailman/listinfo/python-list
========================
Take a look at lib.pdf section 14.1.2  popen3
avoids PIPE problems


Steve



More information about the Python-list mailing list