subprocess.rst 41.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11
:mod:`subprocess` --- Subprocess management
===========================================

.. module:: subprocess
   :synopsis: Subprocess management.
.. moduleauthor:: Peter Åstrand <astrand@lysator.liu.se>
.. sectionauthor:: Peter Åstrand <astrand@lysator.liu.se>


The :mod:`subprocess` module allows you to spawn new processes, connect to their
input/output/error pipes, and obtain their return codes.  This module intends to
Benjamin Peterson's avatar
Benjamin Peterson committed
12
replace several older modules and functions::
13 14 15 16 17 18 19

   os.system
   os.spawn*

Information about how the :mod:`subprocess` module can be used to replace these
modules and functions can be found in the following sections.

Benjamin Peterson's avatar
Benjamin Peterson committed
20 21 22 23
.. seealso::

   :pep:`324` -- PEP proposing the subprocess module

24

25 26
Using the :mod:`subprocess` Module
----------------------------------
27

28 29 30 31 32
The recommended approach to invoking subprocesses is to use the following
convenience functions for all use cases they can handle. For more advanced
use cases, the underlying :class:`Popen` interface can be used directly.


33
.. function:: call(args, *, stdin=None, stdout=None, stderr=None, shell=False, timeout=None)
34 35 36 37 38

   Run the command described by *args*.  Wait for command to complete, then
   return the :attr:`returncode` attribute.

   The arguments shown above are merely the most common ones, described below
39 40 41 42 43 44 45 46 47
   in :ref:`frequently-used-arguments` (hence the use of keyword-only notation
   in the abbreviated signature). The full function signature is largely the
   same as that of the :class:`Popen` constructor - this function passes all
   supplied arguments other than *timeout* directly through to that interface.

   The *timeout* argument is passed to :meth:`Popen.wait`. If the timeout
   expires, the child process will be killed and then waited for again.  The
   :exc:`TimeoutExpired` exception will be re-raised after the child process
   has terminated.
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69

   Examples::

      >>> subprocess.call(["ls", "-l"])
      0

      >>> subprocess.call("exit 1", shell=True)
      1

   .. warning::

      Invoking the system shell with ``shell=True`` can be a security hazard
      if combined with untrusted input. See the warning under
      :ref:`frequently-used-arguments` for details.

   .. note::

      Do not use ``stdout=PIPE`` or ``stderr=PIPE`` with this function. As
      the pipes are not being read in the current process, the child
      process may block if it generates enough output to a pipe to fill up
      the OS pipe buffer.

70 71 72
   .. versionchanged:: 3.3
      *timeout* was added.

73

74
.. function:: check_call(args, *, stdin=None, stdout=None, stderr=None, shell=False, timeout=None)
75 76 77 78

   Run command with arguments.  Wait for command to complete. If the return
   code was zero then return, otherwise raise :exc:`CalledProcessError`. The
   :exc:`CalledProcessError` object will have the return code in the
79
   :attr:`~CalledProcessError.returncode` attribute.
80 81

   The arguments shown above are merely the most common ones, described below
82 83 84 85 86 87 88 89 90
   in :ref:`frequently-used-arguments` (hence the use of keyword-only notation
   in the abbreviated signature). The full function signature is largely the
   same as that of the :class:`Popen` constructor - this function passes all
   supplied arguments other than *timeout* directly through to that interface.

   The *timeout* argument is passed to :meth:`Popen.wait`. If the timeout
   expires, the child process will be killed and then waited for again.  The
   :exc:`TimeoutExpired` exception will be re-raised after the child process
   has terminated.
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114

   Examples::

      >>> subprocess.check_call(["ls", "-l"])
      0

      >>> subprocess.check_call("exit 1", shell=True)
      Traceback (most recent call last):
         ...
      subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1

   .. warning::

      Invoking the system shell with ``shell=True`` can be a security hazard
      if combined with untrusted input. See the warning under
      :ref:`frequently-used-arguments` for details.

   .. note::

      Do not use ``stdout=PIPE`` or ``stderr=PIPE`` with this function. As
      the pipes are not being read in the current process, the child
      process may block if it generates enough output to a pipe to fill up
      the OS pipe buffer.

115 116 117
   .. versionchanged:: 3.3
      *timeout* was added.

118

119
.. function:: check_output(args, *, input=None, stdin=None, stderr=None, shell=False, universal_newlines=False, timeout=None)
120

121
   Run command with arguments and return its output.
122 123 124

   If the return code was non-zero it raises a :exc:`CalledProcessError`. The
   :exc:`CalledProcessError` object will have the return code in the
125 126
   :attr:`~CalledProcessError.returncode` attribute and any output in the
   :attr:`~CalledProcessError.output` attribute.
127 128

   The arguments shown above are merely the most common ones, described below
129 130 131
   in :ref:`frequently-used-arguments` (hence the use of keyword-only notation
   in the abbreviated signature). The full function signature is largely the
   same as that of the :class:`Popen` constructor - this functions passes all
132 133 134
   supplied arguments other than *input* and *timeout* directly through to
   that interface.  In addition, *stdout* is not permitted as an argument, as
   it is used internally to collect the output from the subprocess.
135 136 137 138 139

   The *timeout* argument is passed to :meth:`Popen.wait`. If the timeout
   expires, the child process will be killed and then waited for again.  The
   :exc:`TimeoutExpired` exception will be re-raised after the child process
   has terminated.
140

141 142 143 144 145 146
   The *input* argument is passed to :meth:`Popen.communicate` and thus to the
   subprocess's stdin.  If used it must be a byte sequence, or a string if
   ``universal_newlines=True``.  When used, the internal :class:`Popen` object
   is automatically created with ``stdin=PIPE``, and the *stdin* argument may
   not be used as well.

147 148 149 150 151 152 153 154
   Examples::

      >>> subprocess.check_output(["echo", "Hello World!"])
      b'Hello World!\n'

      >>> subprocess.check_output(["echo", "Hello World!"], universal_newlines=True)
      'Hello World!\n'

155 156 157 158
      >>> subprocess.check_output(["sed", "-e", "s/foo/bar/"],
      ...                         input=b"when in the course of fooman events\n")
      b'when in the course of barman events\n'

159 160 161 162 163 164 165 166 167 168
      >>> subprocess.check_output("exit 1", shell=True)
      Traceback (most recent call last):
         ...
      subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1

   By default, this function will return the data as encoded bytes. The actual
   encoding of the output data may depend on the command being invoked, so the
   decoding to text will often need to be handled at the application level.

   This behaviour may be overridden by setting *universal_newlines* to
169
   ``True`` as described below in :ref:`frequently-used-arguments`.
170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191

   To also capture standard error in the result, use
   ``stderr=subprocess.STDOUT``::

      >>> subprocess.check_output(
      ...     "ls non_existent_file; exit 0",
      ...     stderr=subprocess.STDOUT,
      ...     shell=True)
      'ls: non_existent_file: No such file or directory\n'

   .. warning::

      Invoking the system shell with ``shell=True`` can be a security hazard
      if combined with untrusted input. See the warning under
      :ref:`frequently-used-arguments` for details.

   .. note::

      Do not use ``stderr=PIPE`` with this function. As the pipe is not being
      read in the current process, the child process may block if it
      generates enough output to the pipe to fill up the OS pipe buffer.

192 193
   .. versionadded:: 3.1

194 195 196
   .. versionchanged:: 3.3
      *timeout* was added.

197 198
   .. versionchanged:: 3.4
      *input* was added.
199 200 201 202 203 204 205 206 207

.. data:: DEVNULL

   Special value that can be used as the *stdin*, *stdout* or *stderr* argument
   to :class:`Popen` and indicates that the special file :data:`os.devnull`
   will be used.

   .. versionadded:: 3.3

208 209 210 211 212 213 214 215 216 217 218 219 220 221 222

.. data:: PIPE

   Special value that can be used as the *stdin*, *stdout* or *stderr* argument
   to :class:`Popen` and indicates that a pipe to the standard stream should be
   opened.


.. data:: STDOUT

   Special value that can be used as the *stderr* argument to :class:`Popen` and
   indicates that standard error should go into the same handle as standard
   output.


223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270
.. exception:: SubprocessError

    Base class for all other exceptions from this module.

    .. versionadded:: 3.3


.. exception:: TimeoutExpired

    Subclass of :exc:`SubprocessError`, raised when a timeout expires
    while waiting for a child process.

    .. attribute:: cmd

        Command that was used to spawn the child process.

    .. attribute:: timeout

        Timeout in seconds.

    .. attribute:: output

        Output of the child process if this exception is raised by
        :func:`check_output`.  Otherwise, ``None``.

    .. versionadded:: 3.3


.. exception:: CalledProcessError

    Subclass of :exc:`SubprocessError`, raised when a process run by
    :func:`check_call` or :func:`check_output` returns a non-zero exit status.

    .. attribute:: returncode

        Exit status of the child process.

    .. attribute:: cmd

        Command that was used to spawn the child process.

    .. attribute:: output

        Output of the child process if this exception is raised by
        :func:`check_output`.  Otherwise, ``None``.



271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290
.. _frequently-used-arguments:

Frequently Used Arguments
^^^^^^^^^^^^^^^^^^^^^^^^^

To support a wide variety of use cases, the :class:`Popen` constructor (and
the convenience functions) accept a large number of optional arguments. For
most typical use cases, many of these arguments can be safely left at their
default values. The arguments that are most commonly needed are:

   *args* is required for all calls and should be a string, or a sequence of
   program arguments. Providing a sequence of arguments is generally
   preferred, as it allows the module to take care of any required escaping
   and quoting of arguments (e.g. to permit spaces in file names). If passing
   a single string, either *shell* must be :const:`True` (see below) or else
   the string must simply name the program to be executed without specifying
   any arguments.

   *stdin*, *stdout* and *stderr* specify the executed program's standard input,
   standard output and standard error file handles, respectively.  Valid values
291 292 293 294 295 296 297 298
   are :data:`PIPE`, :data:`DEVNULL`, an existing file descriptor (a positive
   integer), an existing file object, and ``None``.  :data:`PIPE` indicates
   that a new pipe to the child should be created.  :data:`DEVNULL` indicates
   that the special file :data:`os.devnull` will be used.  With the default
   settings of ``None``, no redirection will occur; the child's file handles
   will be inherited from the parent.  Additionally, *stderr* can be
   :data:`STDOUT`, which indicates that the stderr data from the child
   process should be captured into the same file handle as for *stdout*.
299

300 301 302
   .. index::
      single: universal newlines; subprocess module

303 304 305 306 307 308
   If *universal_newlines* is ``False`` the file objects *stdin*, *stdout* and
   *stderr* will be opened as binary streams, and no line ending conversion is
   done.

   If *universal_newlines* is ``True``, these file objects
   will be opened as text streams in :term:`universal newlines` mode
309
   using the encoding returned by :func:`locale.getpreferredencoding(False)
310
   <locale.getpreferredencoding>`.  For *stdin*, line ending characters
311 312 313 314 315
   ``'\n'`` in the input will be converted to the default line separator
   :data:`os.linesep`.  For *stdout* and *stderr*, all line endings in the
   output will be converted to ``'\n'``.  For more information see the
   documentation of the :class:`io.TextIOWrapper` class when the *newline*
   argument to its constructor is ``None``.
316

317 318
   .. note::

319 320 321
      The newlines attribute of the file objects :attr:`Popen.stdin`,
      :attr:`Popen.stdout` and :attr:`Popen.stderr` are not updated by
      the :meth:`Popen.communicate` method.
322 323

   If *shell* is ``True``, the specified command will be executed through
324
   the shell.  This can be useful if you are using Python primarily for the
325
   enhanced control flow it offers over most system shells and still want
326 327 328 329 330 331
   convenient access to other shell features such as shell pipes, filename
   wildcards, environment variable expansion, and expansion of ``~`` to a
   user's home directory.  However, note that Python itself offers
   implementations of many shell-like features (in particular, :mod:`glob`,
   :mod:`fnmatch`, :func:`os.walk`, :func:`os.path.expandvars`,
   :func:`os.path.expanduser`, and :mod:`shutil`).
332

333 334 335 336 337 338
   .. versionchanged:: 3.3
      When *universal_newlines* is ``True``, the class uses the encoding
      :func:`locale.getpreferredencoding(False) <locale.getpreferredencoding>`
      instead of ``locale.getpreferredencoding()``.  See the
      :class:`io.TextIOWrapper` class for more information on this change.

339 340 341 342 343 344
   .. warning::

      Executing shell commands that incorporate unsanitized input from an
      untrusted source makes a program vulnerable to `shell injection
      <http://en.wikipedia.org/wiki/Shell_injection#Shell_injection>`_,
      a serious security flaw which can result in arbitrary command execution.
345 346
      For this reason, the use of ``shell=True`` is **strongly discouraged**
      in cases where the command string is constructed from external input::
347 348 349 350 351 352 353 354 355 356 357

         >>> from subprocess import call
         >>> filename = input("What file would you like to display?\n")
         What file would you like to display?
         non_existent; rm -rf / #
         >>> call("cat " + filename, shell=True) # Uh-oh. This will end badly...

      ``shell=False`` disables all shell based features, but does not suffer
      from this vulnerability; see the Note in the :class:`Popen` constructor
      documentation for helpful hints in getting ``shell=False`` to work.

358 359 360 361
      When using ``shell=True``, :func:`shlex.quote` can be used to properly
      escape whitespace and shell metacharacters in strings that are going to
      be used to construct shell commands.

362 363 364 365
These options, along with all of the other options, are described in more
detail in the :class:`Popen` constructor documentation.


366
Popen Constructor
367
^^^^^^^^^^^^^^^^^
368 369 370 371 372

The underlying process creation and management in this module is handled by
the :class:`Popen` class. It offers a lot of flexibility so that developers
are able to handle the less common cases not covered by the convenience
functions.
373 374


375
.. class:: Popen(args, bufsize=-1, executable=None, stdin=None, stdout=None, \
376 377 378 379
                 stderr=None, preexec_fn=None, close_fds=True, shell=False, \
                 cwd=None, env=None, universal_newlines=False, \
                 startupinfo=None, creationflags=0, restore_signals=True, \
                 start_new_session=False, pass_fds=())
380

381 382 383 384
   Execute a child program in a new process.  On Unix, the class uses
   :meth:`os.execvp`-like behavior to execute the child program.  On Windows,
   the class uses the Windows ``CreateProcess()`` function.  The arguments to
   :class:`Popen` are as follows.
385

386 387
   *args* should be a sequence of program arguments or else a single string.
   By default, the program to execute is the first item in *args* if *args* is
388 389 390 391
   a sequence.  If *args* is a string, the interpretation is
   platform-dependent and described below.  See the *shell* and *executable*
   arguments for additional differences from the default behavior.  Unless
   otherwise stated, it is recommended to pass *args* as a sequence.
392

393 394 395
   On Unix, if *args* is a string, the string is interpreted as the name or
   path of the program to execute.  However, this can only be done if not
   passing arguments to the program.
396 397 398 399 400 401 402

   .. note::

      :meth:`shlex.split` can be useful when determining the correct
      tokenization for *args*, especially in complex cases::

         >>> import shlex, subprocess
403
         >>> command_line = input()
404 405 406 407 408 409 410 411 412 413 414 415
         /bin/vikings -input eggs.txt -output "spam spam.txt" -cmd "echo '$MONEY'"
         >>> args = shlex.split(command_line)
         >>> print(args)
         ['/bin/vikings', '-input', 'eggs.txt', '-output', 'spam spam.txt', '-cmd', "echo '$MONEY'"]
         >>> p = subprocess.Popen(args) # Success!

      Note in particular that options (such as *-input*) and arguments (such
      as *eggs.txt*) that are separated by whitespace in the shell go in separate
      list elements, while arguments that need quoting or backslash escaping when
      used in the shell (such as filenames containing spaces or the *echo* command
      shown above) are single list elements.

416 417 418
   On Windows, if *args* is a sequence, it will be converted to a string in a
   manner described in :ref:`converting-argument-sequence`.  This is because
   the underlying ``CreateProcess()`` operates on strings.
419 420

   The *shell* argument (which defaults to *False*) specifies whether to use
421 422
   the shell as the program to execute.  If *shell* is *True*, it is
   recommended to pass *args* as a string rather than as a sequence.
423 424 425 426

   On Unix with ``shell=True``, the shell defaults to :file:`/bin/sh`.  If
   *args* is a string, the string specifies the command
   to execute through the shell.  This means that the string must be
427 428 429 430
   formatted exactly as it would be when typed at the shell prompt.  This
   includes, for example, quoting or backslash escaping filenames with spaces in
   them.  If *args* is a sequence, the first item specifies the command string, and
   any additional items will be treated as additional arguments to the shell
431
   itself.  That is to say, :class:`Popen` does the equivalent of::
432 433

      Popen(['/bin/sh', '-c', args[0], args[1], ...])
434

435 436 437 438 439
   On Windows with ``shell=True``, the :envvar:`COMSPEC` environment variable
   specifies the default shell.  The only time you need to specify
   ``shell=True`` on Windows is when the command you wish to execute is built
   into the shell (e.g. :command:`dir` or :command:`copy`).  You do not need
   ``shell=True`` to run a batch file or console-based executable.
440

441 442 443 444 445 446
   .. warning::

      Passing ``shell=True`` can be a security hazard if combined with
      untrusted input.  See the warning under :ref:`frequently-used-arguments`
      for details.

447 448 449 450 451 452
   *bufsize* will be supplied as the corresponding argument to the :func:`open`
   function when creating the stdin/stdout/stderr pipe file objects: :const:`0`
   means unbuffered (read and write are one system call and can return short),
   :const:`1` means line buffered, any other positive value means use a buffer
   of approximately that size.  A negative bufsize (the default) means the
   system default of io.DEFAULT_BUFFER_SIZE will be used.
453

454
   .. versionchanged:: 3.3.1
455
      *bufsize* now defaults to -1 to enable buffering by default to match the
456 457 458 459
      behavior that most code expects.  In versions prior to Python 3.2.4 and
      3.3.1 it incorrectly defaulted to :const:`0` which was unbuffered
      and allowed short reads.  This was unintentional and did not match the
      behavior of Python 2 as most code expected.
460

461 462
   The *executable* argument specifies a replacement program to execute.   It
   is very seldom needed.  When ``shell=False``, *executable* replaces the
463 464 465 466
   program to execute specified by *args*.  However, the original *args* is
   still passed to the program.  Most programs treat the program specified
   by *args* as the command name, which can then be different from the program
   actually executed.  On Unix, the *args* name
467 468 469
   becomes the display name for the executable in utilities such as
   :program:`ps`.  If ``shell=True``, on Unix the *executable* argument
   specifies a replacement shell for the default :file:`/bin/sh`.
470

471
   *stdin*, *stdout* and *stderr* specify the executed program's standard input,
Georg Brandl's avatar
Georg Brandl committed
472
   standard output and standard error file handles, respectively.  Valid values
473 474 475
   are :data:`PIPE`, :data:`DEVNULL`, an existing file descriptor (a positive
   integer), an existing :term:`file object`, and ``None``.  :data:`PIPE`
   indicates that a new pipe to the child should be created.  :data:`DEVNULL`
476 477 478 479 480
   indicates that the special file :data:`os.devnull` will be used. With the
   default settings of ``None``, no redirection will occur; the child's file
   handles will be inherited from the parent.  Additionally, *stderr* can be
   :data:`STDOUT`, which indicates that the stderr data from the applications
   should be captured into the same file handle as for stdout.
481 482

   If *preexec_fn* is set to a callable object, this object will be called in the
483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499
   child process just before the child is executed.
   (Unix only)

   .. warning::

      The *preexec_fn* parameter is not safe to use in the presence of threads
      in your application.  The child process could deadlock before exec is
      called.
      If you must use it, keep it trivial!  Minimize the number of libraries
      you call into.

   .. note::

      If you need to modify the environment for the child use the *env*
      parameter rather than doing it in a *preexec_fn*.
      The *start_new_session* parameter can take the place of a previously
      common use of *preexec_fn* to call os.setsid() in the child.
500 501 502

   If *close_fds* is true, all file descriptors except :const:`0`, :const:`1` and
   :const:`2` will be closed before the child process is executed. (Unix only).
503 504
   The default varies by platform:  Always true on Unix.  On Windows it is
   true when *stdin*/*stdout*/*stderr* are :const:`None`, false otherwise.
505
   On Windows, if *close_fds* is true then no handles will be inherited by the
506 507 508
   child process.  Note that on Windows, you cannot set *close_fds* to true and
   also redirect the standard handles by setting *stdin*, *stdout* or *stderr*.

509 510 511 512 513 514 515 516 517 518
   .. versionchanged:: 3.2
      The default for *close_fds* was changed from :const:`False` to
      what is described above.

   *pass_fds* is an optional sequence of file descriptors to keep open
   between the parent and child.  Providing any *pass_fds* forces
   *close_fds* to be :const:`True`.  (Unix only)

   .. versionadded:: 3.2
      The *pass_fds* parameter was added.
519

520 521 522 523
   If *cwd* is not ``None``, the function changes the working directory to
   *cwd* before executing the child.  In particular, the function looks for
   *executable* (or for the first item in *args*) relative to *cwd* if the
   executable path is a relative path.
524

525
   If *restore_signals* is true (the default) all signals that Python has set to
526 527 528 529 530 531 532
   SIG_IGN are restored to SIG_DFL in the child process before the exec.
   Currently this includes the SIGPIPE, SIGXFZ and SIGXFSZ signals.
   (Unix only)

   .. versionchanged:: 3.2
      *restore_signals* was added.

533
   If *start_new_session* is true the setsid() system call will be made in the
534 535 536 537 538
   child process prior to the execution of the subprocess.  (Unix only)

   .. versionchanged:: 3.2
      *start_new_session* was added.

Christian Heimes's avatar
Christian Heimes committed
539
   If *env* is not ``None``, it must be a mapping that defines the environment
540 541
   variables for the new process; these are used instead of the default
   behavior of inheriting the current process' environment.
542

543
   .. note::
544

545 546 547
      If specified, *env* must provide any variables required for the program to
      execute.  On Windows, in order to run a `side-by-side assembly`_ the
      specified *env* **must** include a valid :envvar:`SystemRoot`.
548

549 550
   .. _side-by-side assembly: http://en.wikipedia.org/wiki/Side-by-Side_Assembly

551
   If *universal_newlines* is ``True``, the file objects *stdin*, *stdout*
552
   and *stderr* are opened as text streams in universal newlines mode, as
553 554
   described above in :ref:`frequently-used-arguments`, otherwise they are
   opened as binary streams.
555

556 557
   If given, *startupinfo* will be a :class:`STARTUPINFO` object, which is
   passed to the underlying ``CreateProcess`` function.
558 559
   *creationflags*, if given, can be :data:`CREATE_NEW_CONSOLE` or
   :data:`CREATE_NEW_PROCESS_GROUP`. (Windows only)
560

561 562
   Popen objects are supported as context managers via the :keyword:`with` statement:
   on exit, standard file descriptors are closed, and the process is waited for.
563 564 565 566 567 568 569 570
   ::

      with Popen(["ifconfig"], stdout=PIPE) as proc:
          log.write(proc.stdout.read())

   .. versionchanged:: 3.2
      Added context manager support.

571 572 573 574 575 576 577

Exceptions
^^^^^^^^^^

Exceptions raised in the child process, before the new program has started to
execute, will be re-raised in the parent.  Additionally, the exception object
will have one extra attribute called :attr:`child_traceback`, which is a string
Georg Brandl's avatar
Georg Brandl committed
578
containing traceback information from the child's point of view.
579 580 581 582 583 584 585 586

The most common exception raised is :exc:`OSError`.  This occurs, for example,
when trying to execute a non-existent file.  Applications should prepare for
:exc:`OSError` exceptions.

A :exc:`ValueError` will be raised if :class:`Popen` is called with invalid
arguments.

587 588 589
:func:`check_call` and :func:`check_output` will raise
:exc:`CalledProcessError` if the called process returns a non-zero return
code.
590

591 592 593 594
All of the functions and methods that accept a *timeout* parameter, such as
:func:`call` and :meth:`Popen.communicate` will raise :exc:`TimeoutExpired` if
the timeout expires before the process exits.

595
Exceptions defined in this module all inherit from :exc:`SubprocessError`.
596 597 598 599

   .. versionadded:: 3.3
      The :exc:`SubprocessError` base class was added.

600 601 602 603

Security
^^^^^^^^

604 605 606 607 608
Unlike some other popen functions, this implementation will never call a
system shell implicitly.  This means that all characters, including shell
metacharacters, can safely be passed to child processes. Obviously, if the
shell is invoked explicitly, then it is the application's responsibility to
ensure that all whitespace and metacharacters are quoted appropriately.
609 610 611 612 613 614 615 616 617 618


Popen Objects
-------------

Instances of the :class:`Popen` class have the following methods:


.. method:: Popen.poll()

619 620
   Check if child process has terminated.  Set and return
   :attr:`~Popen.returncode` attribute.
621 622


623
.. method:: Popen.wait(timeout=None)
624

625 626
   Wait for child process to terminate.  Set and return
   :attr:`~Popen.returncode` attribute.
627

628 629 630 631
   If the process does not terminate after *timeout* seconds, raise a
   :exc:`TimeoutExpired` exception.  It is safe to catch this exception and
   retry the wait.

632 633 634 635 636 637
   .. note::

      The function is implemented using a busy loop (non-blocking call and
      short sleeps). Use the :mod:`asyncio` module for an asynchronous wait:
      see :class:`asyncio.create_subprocess_exec`.

Georg Brandl's avatar
Georg Brandl committed
638 639
   .. warning::

640 641 642 643
      This will deadlock when using ``stdout=PIPE`` and/or
      ``stderr=PIPE`` and the child process generates enough output to
      a pipe such that it blocks waiting for the OS pipe buffer to
      accept more data.  Use :meth:`communicate` to avoid that.
Georg Brandl's avatar
Georg Brandl committed
644

645
   .. versionchanged:: 3.3
646
      *timeout* was added.
647

648 649 650 651 652
   .. deprecated:: 3.4

      Do not use the undocumented *endtime* parameter.  It is was
      unintentionally exposed in 3.3 but was intended to be private
      for internal use.  Use *timeout* instead.
653 654

.. method:: Popen.communicate(input=None, timeout=None)
655 656

   Interact with process: Send data to stdin.  Read data from stdout and stderr,
657
   until end-of-file is reached.  Wait for process to terminate.  The optional
658 659 660
   *input* argument should be data to be sent to the child process, or
   ``None``, if no data should be sent to the child.  The type of *input*
   must be bytes or, if *universal_newlines* was ``True``, a string.
661

Georg Brandl's avatar
Georg Brandl committed
662
   :meth:`communicate` returns a tuple ``(stdoutdata, stderrdata)``.
663

664 665 666 667 668
   Note that if you want to send data to the process's stdin, you need to create
   the Popen object with ``stdin=PIPE``.  Similarly, to get anything other than
   ``None`` in the result tuple, you need to give ``stdout=PIPE`` and/or
   ``stderr=PIPE`` too.

669 670 671 672 673 674 675 676 677 678 679 680 681 682 683
   If the process does not terminate after *timeout* seconds, a
   :exc:`TimeoutExpired` exception will be raised.  Catching this exception and
   retrying communication will not lose any output.

   The child process is not killed if the timeout expires, so in order to
   cleanup properly a well-behaved application should kill the child process and
   finish communication::

      proc = subprocess.Popen(...)
      try:
          outs, errs = proc.communicate(timeout=15)
      except TimeoutExpired:
          proc.kill()
          outs, errs = proc.communicate()

684
   .. note::
685

686 687
      The data read is buffered in memory, so do not use this method if the data
      size is large or unlimited.
688

689
   .. versionchanged:: 3.3
690 691
      *timeout* was added.

692

Christian Heimes's avatar
Christian Heimes committed
693 694 695 696 697 698
.. method:: Popen.send_signal(signal)

   Sends the signal *signal* to the child.

   .. note::

699
      On Windows, SIGTERM is an alias for :meth:`terminate`. CTRL_C_EVENT and
700
      CTRL_BREAK_EVENT can be sent to processes started with a *creationflags*
701
      parameter which includes `CREATE_NEW_PROCESS_GROUP`.
Christian Heimes's avatar
Christian Heimes committed
702 703 704 705 706


.. method:: Popen.terminate()

   Stop the child. On Posix OSs the method sends SIGTERM to the
707
   child. On Windows the Win32 API function :c:func:`TerminateProcess` is called
Christian Heimes's avatar
Christian Heimes committed
708 709 710 711 712 713 714 715 716
   to stop the child.


.. method:: Popen.kill()

   Kills the child. On Posix OSs the function sends SIGKILL to the child.
   On Windows :meth:`kill` is an alias for :meth:`terminate`.


717
The following attributes are also available:
718

Georg Brandl's avatar
Georg Brandl committed
719 720
.. warning::

721 722
   Use :meth:`~Popen.communicate` rather than :attr:`.stdin.write <Popen.stdin>`,
   :attr:`.stdout.read <Popen.stdout>` or :attr:`.stderr.read <Popen.stderr>` to avoid
723 724
   deadlocks due to any of the other OS pipe buffers filling up and blocking the
   child process.
Georg Brandl's avatar
Georg Brandl committed
725 726


727 728
.. attribute:: Popen.stdin

729 730 731 732 733
   If the *stdin* argument was :data:`PIPE`, this attribute is a writeable
   stream object as returned by :func:`open`. If the *universal_newlines*
   argument was ``True``, the stream is a text stream, otherwise it is a byte
   stream. If the *stdin* argument was not :data:`PIPE`, this attribute is
   ``None``.
734 735 736 737


.. attribute:: Popen.stdout

738 739 740 741 742
   If the *stdout* argument was :data:`PIPE`, this attribute is a readable
   stream object as returned by :func:`open`. Reading from the stream provides
   output from the child process. If the *universal_newlines* argument was
   ``True``, the stream is a text stream, otherwise it is a byte stream. If the
   *stdout* argument was not :data:`PIPE`, this attribute is ``None``.
Benjamin Peterson's avatar
Benjamin Peterson committed
743

744 745 746

.. attribute:: Popen.stderr

747 748 749 750 751
   If the *stderr* argument was :data:`PIPE`, this attribute is a readable
   stream object as returned by :func:`open`. Reading from the stream provides
   error output from the child process. If the *universal_newlines* argument was
   ``True``, the stream is a text stream, otherwise it is a byte stream. If the
   *stderr* argument was not :data:`PIPE`, this attribute is ``None``.
752 753 754 755 756 757


.. attribute:: Popen.pid

   The process ID of the child process.

758 759 760
   Note that if you set the *shell* argument to ``True``, this is the process ID
   of the spawned shell.

761 762 763

.. attribute:: Popen.returncode

764 765 766
   The child return code, set by :meth:`poll` and :meth:`wait` (and indirectly
   by :meth:`communicate`).  A ``None`` value indicates that the process
   hasn't terminated yet.
767

768 769
   A negative value ``-N`` indicates that the child was terminated by signal
   ``N`` (Unix only).
770 771


772 773 774 775 776 777 778
Windows Popen Helpers
---------------------

The :class:`STARTUPINFO` class and following constants are only available
on Windows.

.. class:: STARTUPINFO()
Brian Curtin's avatar
Brian Curtin committed
779

780 781 782 783 784 785
   Partial support of the Windows
   `STARTUPINFO <http://msdn.microsoft.com/en-us/library/ms686331(v=vs.85).aspx>`__
   structure is used for :class:`Popen` creation.

   .. attribute:: dwFlags

786 787
      A bit field that determines whether certain :class:`STARTUPINFO`
      attributes are used when the process creates a window. ::
788 789 790 791 792 793

         si = subprocess.STARTUPINFO()
         si.dwFlags = subprocess.STARTF_USESTDHANDLES | subprocess.STARTF_USESHOWWINDOW

   .. attribute:: hStdInput

794 795 796 797
      If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
      is the standard input handle for the process. If
      :data:`STARTF_USESTDHANDLES` is not specified, the default for standard
      input is the keyboard buffer.
798 799 800

   .. attribute:: hStdOutput

801 802 803
      If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
      is the standard output handle for the process. Otherwise, this attribute
      is ignored and the default for standard output is the console window's
804 805 806 807
      buffer.

   .. attribute:: hStdError

808 809
      If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
      is the standard error handle for the process. Otherwise, this attribute is
810 811 812 813
      ignored and the default for standard error is the console window's buffer.

   .. attribute:: wShowWindow

814
      If :attr:`dwFlags` specifies :data:`STARTF_USESHOWWINDOW`, this attribute
815 816 817
      can be any of the values that can be specified in the ``nCmdShow``
      parameter for the
      `ShowWindow <http://msdn.microsoft.com/en-us/library/ms633548(v=vs.85).aspx>`__
818
      function, except for ``SW_SHOWDEFAULT``. Otherwise, this attribute is
819
      ignored.
Brian Curtin's avatar
Brian Curtin committed
820

821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851
      :data:`SW_HIDE` is provided for this attribute. It is used when
      :class:`Popen` is called with ``shell=True``.


Constants
^^^^^^^^^

The :mod:`subprocess` module exposes the following constants.

.. data:: STD_INPUT_HANDLE

   The standard input device. Initially, this is the console input buffer,
   ``CONIN$``.

.. data:: STD_OUTPUT_HANDLE

   The standard output device. Initially, this is the active console screen
   buffer, ``CONOUT$``.

.. data:: STD_ERROR_HANDLE

   The standard error device. Initially, this is the active console screen
   buffer, ``CONOUT$``.

.. data:: SW_HIDE

   Hides the window. Another window will be activated.

.. data:: STARTF_USESTDHANDLES

   Specifies that the :attr:`STARTUPINFO.hStdInput`,
852
   :attr:`STARTUPINFO.hStdOutput`, and :attr:`STARTUPINFO.hStdError` attributes
853 854 855 856
   contain additional information.

.. data:: STARTF_USESHOWWINDOW

857
   Specifies that the :attr:`STARTUPINFO.wShowWindow` attribute contains
858 859 860 861 862 863
   additional information.

.. data:: CREATE_NEW_CONSOLE

   The new process has a new console, instead of inheriting its parent's
   console (the default).
Brian Curtin's avatar
Brian Curtin committed
864

865 866 867 868 869 870 871 872
.. data:: CREATE_NEW_PROCESS_GROUP

   A :class:`Popen` ``creationflags`` parameter to specify that a new process
   group will be created. This flag is necessary for using :func:`os.kill`
   on the subprocess.

   This flag is ignored if :data:`CREATE_NEW_CONSOLE` is specified.

873

Benjamin Peterson's avatar
Benjamin Peterson committed
874 875
.. _subprocess-replacements:

876 877
Replacing Older Functions with the :mod:`subprocess` Module
-----------------------------------------------------------
878

879
In this section, "a becomes b" means that b can be used as a replacement for a.
880 881 882

.. note::

883 884 885
   All "a" functions in this section fail (more or less) silently if the
   executed program cannot be found; the "b" replacements raise :exc:`OSError`
   instead.
886

887 888
   In addition, the replacements using :func:`check_output` will fail with a
   :exc:`CalledProcessError` if the requested operation produces a non-zero
889 890
   return code. The output is still available as the
   :attr:`~CalledProcessError.output` attribute of the raised exception.
891 892

In the following examples, we assume that the relevant functions have already
893
been imported from the :mod:`subprocess` module.
894 895 896 897 898 899 900 901


Replacing /bin/sh shell backquote
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

::

   output=`mycmd myarg`
902 903
   # becomes
   output = check_output(["mycmd", "myarg"])
904 905


Benjamin Peterson's avatar
Benjamin Peterson committed
906 907
Replacing shell pipeline
^^^^^^^^^^^^^^^^^^^^^^^^
908 909 910 911

::

   output=`dmesg | grep hda`
912
   # becomes
913 914
   p1 = Popen(["dmesg"], stdout=PIPE)
   p2 = Popen(["grep", "hda"], stdin=p1.stdout, stdout=PIPE)
915
   p1.stdout.close()  # Allow p1 to receive a SIGPIPE if p2 exits.
916 917
   output = p2.communicate()[0]

918 919
The p1.stdout.close() call after starting the p2 is important in order for p1
to receive a SIGPIPE if p2 exits before p1.
920

921
Alternatively, for trusted input, the shell's own pipeline support may still
922
be used directly::
923 924 925 926 927 928

   output=`dmesg | grep hda`
   # becomes
   output=check_output("dmesg | grep hda", shell=True)


Benjamin Peterson's avatar
Benjamin Peterson committed
929 930
Replacing :func:`os.system`
^^^^^^^^^^^^^^^^^^^^^^^^^^^
931 932 933 934

::

   sts = os.system("mycmd" + " myarg")
935 936
   # becomes
   sts = call("mycmd" + " myarg", shell=True)
937 938 939 940 941 942 943 944 945 946

Notes:

* Calling the program through the shell is usually not required.

A more realistic example would look like this::

   try:
       retcode = call("mycmd" + " myarg", shell=True)
       if retcode < 0:
947
           print("Child was terminated by signal", -retcode, file=sys.stderr)
948
       else:
949
           print("Child returned", retcode, file=sys.stderr)
950
   except OSError as e:
951
       print("Execution failed:", e, file=sys.stderr)
952 953


Benjamin Peterson's avatar
Benjamin Peterson committed
954 955
Replacing the :func:`os.spawn <os.spawnl>` family
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981

P_NOWAIT example::

   pid = os.spawnlp(os.P_NOWAIT, "/bin/mycmd", "mycmd", "myarg")
   ==>
   pid = Popen(["/bin/mycmd", "myarg"]).pid

P_WAIT example::

   retcode = os.spawnlp(os.P_WAIT, "/bin/mycmd", "mycmd", "myarg")
   ==>
   retcode = call(["/bin/mycmd", "myarg"])

Vector example::

   os.spawnvp(os.P_NOWAIT, path, args)
   ==>
   Popen([path] + args[1:])

Environment example::

   os.spawnlpe(os.P_NOWAIT, "/bin/mycmd", "mycmd", "myarg", env)
   ==>
   Popen(["/bin/mycmd", "myarg"], env={"PATH": "/usr/bin"})


Benjamin Peterson's avatar
Benjamin Peterson committed
982 983 984

Replacing :func:`os.popen`, :func:`os.popen2`, :func:`os.popen3`
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
985 986 987

::

Benjamin Peterson's avatar
Benjamin Peterson committed
988
   (child_stdin, child_stdout) = os.popen2(cmd, mode, bufsize)
989
   ==>
Benjamin Peterson's avatar
Benjamin Peterson committed
990 991 992
   p = Popen(cmd, shell=True, bufsize=bufsize,
             stdin=PIPE, stdout=PIPE, close_fds=True)
   (child_stdin, child_stdout) = (p.stdin, p.stdout)
993 994 995

::

Benjamin Peterson's avatar
Benjamin Peterson committed
996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018
   (child_stdin,
    child_stdout,
    child_stderr) = os.popen3(cmd, mode, bufsize)
   ==>
   p = Popen(cmd, shell=True, bufsize=bufsize,
             stdin=PIPE, stdout=PIPE, stderr=PIPE, close_fds=True)
   (child_stdin,
    child_stdout,
    child_stderr) = (p.stdin, p.stdout, p.stderr)

::

   (child_stdin, child_stdout_and_stderr) = os.popen4(cmd, mode, bufsize)
   ==>
   p = Popen(cmd, shell=True, bufsize=bufsize,
             stdin=PIPE, stdout=PIPE, stderr=STDOUT, close_fds=True)
   (child_stdin, child_stdout_and_stderr) = (p.stdin, p.stdout)

Return code handling translates as follows::

   pipe = os.popen(cmd, 'w')
   ...
   rc = pipe.close()
1019
   if rc is not None and rc >> 8:
1020
       print("There were some errors")
1021
   ==>
Benjamin Peterson's avatar
Benjamin Peterson committed
1022 1023 1024 1025
   process = Popen(cmd, 'w', stdin=PIPE)
   ...
   process.stdin.close()
   if process.wait() != 0:
1026
       print("There were some errors")
Benjamin Peterson's avatar
Benjamin Peterson committed
1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062


Replacing functions from the :mod:`popen2` module
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

.. note::

   If the cmd argument to popen2 functions is a string, the command is executed
   through /bin/sh.  If it is a list, the command is directly executed.

::

   (child_stdout, child_stdin) = popen2.popen2("somestring", bufsize, mode)
   ==>
   p = Popen(["somestring"], shell=True, bufsize=bufsize,
             stdin=PIPE, stdout=PIPE, close_fds=True)
   (child_stdout, child_stdin) = (p.stdout, p.stdin)

::

   (child_stdout, child_stdin) = popen2.popen2(["mycmd", "myarg"], bufsize, mode)
   ==>
   p = Popen(["mycmd", "myarg"], bufsize=bufsize,
             stdin=PIPE, stdout=PIPE, close_fds=True)
   (child_stdout, child_stdin) = (p.stdout, p.stdin)

:class:`popen2.Popen3` and :class:`popen2.Popen4` basically work as
:class:`subprocess.Popen`, except that:

* :class:`Popen` raises an exception if the execution fails.

* the *capturestderr* argument is replaced with the *stderr* argument.

* ``stdin=PIPE`` and ``stdout=PIPE`` must be specified.

* popen2 closes all file descriptors by default, but you have to specify
1063 1064
  ``close_fds=True`` with :class:`Popen` to guarantee this behavior on
  all platforms or past Python versions.
1065

1066 1067

Legacy Shell Invocation Functions
1068
---------------------------------
1069 1070 1071 1072 1073 1074 1075 1076 1077 1078

This module also provides the following legacy functions from the 2.x
``commands`` module. These operations implicitly invoke the system shell and
none of the guarantees described above regarding security and exception
handling consistency are valid for these functions.

.. function:: getstatusoutput(cmd)

   Return ``(status, output)`` of executing *cmd* in a shell.

1079 1080 1081
   Execute the string *cmd* in a shell with :meth:`Popen.check_output` and
   return a 2-tuple ``(status, output)``. Universal newlines mode is used;
   see the notes on :ref:`frequently-used-arguments` for more details.
1082 1083 1084

   A trailing newline is stripped from the output.
   The exit status for the command can be interpreted
1085 1086 1087 1088 1089 1090 1091 1092 1093
   according to the rules for the C function :c:func:`wait`.  Example::

      >>> subprocess.getstatusoutput('ls /bin/ls')
      (0, '/bin/ls')
      >>> subprocess.getstatusoutput('cat /bin/junk')
      (256, 'cat: /bin/junk: No such file or directory')
      >>> subprocess.getstatusoutput('/bin/junk')
      (256, 'sh: /bin/junk: not found')

1094 1095 1096 1097
   Availability: Unix & Windows

   .. versionchanged:: 3.3.4
      Windows support added
1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109


.. function:: getoutput(cmd)

   Return output (stdout and stderr) of executing *cmd* in a shell.

   Like :func:`getstatusoutput`, except the exit status is ignored and the return
   value is a string containing the command's output.  Example::

      >>> subprocess.getoutput('ls /bin/ls')
      '/bin/ls'

1110 1111 1112 1113
   Availability: Unix & Windows

   .. versionchanged:: 3.3.4
      Windows support added
1114

1115

1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147
Notes
-----

.. _converting-argument-sequence:

Converting an argument sequence to a string on Windows
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

On Windows, an *args* sequence is converted to a string that can be parsed
using the following rules (which correspond to the rules used by the MS C
runtime):

1. Arguments are delimited by white space, which is either a
   space or a tab.

2. A string surrounded by double quotation marks is
   interpreted as a single argument, regardless of white space
   contained within.  A quoted string can be embedded in an
   argument.

3. A double quotation mark preceded by a backslash is
   interpreted as a literal double quotation mark.

4. Backslashes are interpreted literally, unless they
   immediately precede a double quotation mark.

5. If backslashes immediately precede a double quotation mark,
   every pair of backslashes is interpreted as a literal
   backslash.  If the number of backslashes is odd, the last
   backslash escapes the next double quotation mark as
   described in rule 3.

Eli Bendersky's avatar
Eli Bendersky committed
1148

1149 1150 1151 1152
.. seealso::

   :mod:`shlex`
      Module which provides function to parse and escape command lines.