blob: 67bee40acb68b20762bff3ee59fae0a029007b8c [file] [log] [blame]
Georg Brandl116aa622007-08-15 14:28:22 +00001:mod:`subprocess` --- Subprocess management
2===========================================
3
4.. module:: subprocess
5 :synopsis: Subprocess management.
6.. moduleauthor:: Peter Åstrand <astrand@lysator.liu.se>
7.. sectionauthor:: Peter Åstrand <astrand@lysator.liu.se>
8
9
Georg Brandl116aa622007-08-15 14:28:22 +000010The :mod:`subprocess` module allows you to spawn new processes, connect to their
11input/output/error pipes, and obtain their return codes. This module intends to
Benjamin Peterson5eea8a72014-03-12 21:41:35 -050012replace several older modules and functions::
Georg Brandl116aa622007-08-15 14:28:22 +000013
14 os.system
15 os.spawn*
Georg Brandl116aa622007-08-15 14:28:22 +000016
17Information about how the :mod:`subprocess` module can be used to replace these
18modules and functions can be found in the following sections.
19
Benjamin Peterson41181742008-07-02 20:22:54 +000020.. seealso::
21
22 :pep:`324` -- PEP proposing the subprocess module
23
Georg Brandl116aa622007-08-15 14:28:22 +000024
Ezio Melotti402f75d2012-11-08 10:07:10 +020025Using the :mod:`subprocess` Module
26----------------------------------
Georg Brandl116aa622007-08-15 14:28:22 +000027
Gregory P. Smith6e730002015-04-14 16:14:25 -070028The recommended approach to invoking subprocesses is to use the :func:`run`
Benjamin Petersonef9ffcb2015-04-14 22:12:14 -040029function for all use cases it can handle. For more advanced use cases, the
30underlying :class:`Popen` interface can be used directly.
Nick Coghlanc29248f2011-11-08 20:49:23 +100031
Gregory P. Smith6e730002015-04-14 16:14:25 -070032The :func:`run` function was added in Python 3.5; if you need to retain
33compatibility with older versions, see the :ref:`call-function-trio` section.
Nick Coghlanc29248f2011-11-08 20:49:23 +100034
Gregory P. Smith6e730002015-04-14 16:14:25 -070035
36.. function:: run(args, *, stdin=None, input=None, stdout=None, stderr=None,\
37 shell=False, timeout=None, check=False)
Nick Coghlanc29248f2011-11-08 20:49:23 +100038
39 Run the command described by *args*. Wait for command to complete, then
Gregory P. Smith6e730002015-04-14 16:14:25 -070040 return a :class:`CompletedProcess` instance.
Nick Coghlanc29248f2011-11-08 20:49:23 +100041
42 The arguments shown above are merely the most common ones, described below
Nick Coghlan217f05b2011-11-08 22:11:21 +100043 in :ref:`frequently-used-arguments` (hence the use of keyword-only notation
44 in the abbreviated signature). The full function signature is largely the
Gregory P. Smith6e730002015-04-14 16:14:25 -070045 same as that of the :class:`Popen` constructor - apart from *timeout*,
46 *input* and *check*, all the arguments to this function are passed through to
47 that interface.
Nick Coghlan217f05b2011-11-08 22:11:21 +100048
Gregory P. Smith6e730002015-04-14 16:14:25 -070049 This does not capture stdout or stderr by default. To do so, pass
50 :data:`PIPE` for the *stdout* and/or *stderr* arguments.
Nick Coghlanc29248f2011-11-08 20:49:23 +100051
Gregory P. Smith6e730002015-04-14 16:14:25 -070052 The *timeout* argument is passed to :meth:`Popen.communicate`. If the timeout
53 expires, the child process will be killed and waited for. The
Nick Coghlan217f05b2011-11-08 22:11:21 +100054 :exc:`TimeoutExpired` exception will be re-raised after the child process
55 has terminated.
Nick Coghlanc29248f2011-11-08 20:49:23 +100056
Serhiy Storchakafcd9f222013-04-22 20:20:54 +030057 The *input* argument is passed to :meth:`Popen.communicate` and thus to the
58 subprocess's stdin. If used it must be a byte sequence, or a string if
59 ``universal_newlines=True``. When used, the internal :class:`Popen` object
60 is automatically created with ``stdin=PIPE``, and the *stdin* argument may
61 not be used as well.
62
Gregory P. Smith6e730002015-04-14 16:14:25 -070063 If *check* is True, and the process exits with a non-zero exit code, a
64 :exc:`CalledProcessError` exception will be raised. Attributes of that
65 exception hold the arguments, the exit code, and stdout and stderr if they
66 were captured.
67
Nick Coghlanc29248f2011-11-08 20:49:23 +100068 Examples::
69
Gregory P. Smith6e730002015-04-14 16:14:25 -070070 >>> subprocess.run(["ls", "-l"]) # doesn't capture output
71 CompletedProcess(args=['ls', '-l'], returncode=0)
Nick Coghlanc29248f2011-11-08 20:49:23 +100072
Gregory P. Smith6e730002015-04-14 16:14:25 -070073 >>> subprocess.run("exit 1", shell=True, check=True)
Nick Coghlanc29248f2011-11-08 20:49:23 +100074 Traceback (most recent call last):
Gregory P. Smith6e730002015-04-14 16:14:25 -070075 ...
Nick Coghlanc29248f2011-11-08 20:49:23 +100076 subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1
77
Gregory P. Smith6e730002015-04-14 16:14:25 -070078 >>> subprocess.run(["ls", "-l", "/dev/null"], stdout=subprocess.PIPE)
79 CompletedProcess(args=['ls', '-l', '/dev/null'], returncode=0,
80 stdout=b'crw-rw-rw- 1 root root 1, 3 Jan 23 16:23 /dev/null\n')
Nick Coghlanc29248f2011-11-08 20:49:23 +100081
Gregory P. Smith6e730002015-04-14 16:14:25 -070082 .. versionadded:: 3.5
Nick Coghlanc29248f2011-11-08 20:49:23 +100083
Gregory P. Smith6e730002015-04-14 16:14:25 -070084.. class:: CompletedProcess
Nick Coghlanc29248f2011-11-08 20:49:23 +100085
Gregory P. Smith6e730002015-04-14 16:14:25 -070086 The return value from :func:`run`, representing a process that has finished.
Nick Coghlanc29248f2011-11-08 20:49:23 +100087
Gregory P. Smith6e730002015-04-14 16:14:25 -070088 .. attribute:: args
Nick Coghlanc29248f2011-11-08 20:49:23 +100089
Gregory P. Smith6e730002015-04-14 16:14:25 -070090 The arguments used to launch the process. This may be a list or a string.
Nick Coghlanc29248f2011-11-08 20:49:23 +100091
Gregory P. Smith6e730002015-04-14 16:14:25 -070092 .. attribute:: returncode
Serhiy Storchakafcd9f222013-04-22 20:20:54 +030093
Gregory P. Smith6e730002015-04-14 16:14:25 -070094 Exit status of the child process. Typically, an exit status of 0 indicates
95 that it ran successfully.
Nick Coghlan217f05b2011-11-08 22:11:21 +100096
Gregory P. Smith6e730002015-04-14 16:14:25 -070097 A negative value ``-N`` indicates that the child was terminated by signal
98 ``N`` (POSIX only).
99
100 .. attribute:: stdout
101
102 Captured stdout from the child process. A bytes sequence, or a string if
103 :func:`run` was called with ``universal_newlines=True``. None if stdout
104 was not captured.
105
106 If you ran the process with ``stderr=subprocess.STDOUT``, stdout and
107 stderr will be combined in this attribute, and :attr:`stderr` will be
108 None.
109
110 .. attribute:: stderr
111
112 Captured stderr from the child process. A bytes sequence, or a string if
113 :func:`run` was called with ``universal_newlines=True``. None if stderr
114 was not captured.
115
116 .. method:: check_returncode()
117
118 If :attr:`returncode` is non-zero, raise a :exc:`CalledProcessError`.
119
120 .. versionadded:: 3.5
Nick Coghlan217f05b2011-11-08 22:11:21 +1000121
122.. data:: DEVNULL
123
124 Special value that can be used as the *stdin*, *stdout* or *stderr* argument
125 to :class:`Popen` and indicates that the special file :data:`os.devnull`
126 will be used.
127
128 .. versionadded:: 3.3
129
Nick Coghlanc29248f2011-11-08 20:49:23 +1000130
131.. data:: PIPE
132
133 Special value that can be used as the *stdin*, *stdout* or *stderr* argument
134 to :class:`Popen` and indicates that a pipe to the standard stream should be
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700135 opened. Most useful with :meth:`Popen.communicate`.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000136
137
138.. data:: STDOUT
139
140 Special value that can be used as the *stderr* argument to :class:`Popen` and
141 indicates that standard error should go into the same handle as standard
142 output.
143
144
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300145.. exception:: SubprocessError
146
147 Base class for all other exceptions from this module.
148
149 .. versionadded:: 3.3
150
151
152.. exception:: TimeoutExpired
153
154 Subclass of :exc:`SubprocessError`, raised when a timeout expires
155 while waiting for a child process.
156
157 .. attribute:: cmd
158
159 Command that was used to spawn the child process.
160
161 .. attribute:: timeout
162
163 Timeout in seconds.
164
165 .. attribute:: output
166
Gregory P. Smith6e730002015-04-14 16:14:25 -0700167 Output of the child process if it was captured by :func:`run` or
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300168 :func:`check_output`. Otherwise, ``None``.
169
Gregory P. Smith6e730002015-04-14 16:14:25 -0700170 .. attribute:: stdout
171
172 Alias for output, for symmetry with :attr:`stderr`.
173
174 .. attribute:: stderr
175
176 Stderr output of the child process if it was captured by :func:`run`.
177 Otherwise, ``None``.
178
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300179 .. versionadded:: 3.3
180
Gregory P. Smith6e730002015-04-14 16:14:25 -0700181 .. versionchanged:: 3.5
182 *stdout* and *stderr* attributes added
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300183
184.. exception:: CalledProcessError
185
186 Subclass of :exc:`SubprocessError`, raised when a process run by
187 :func:`check_call` or :func:`check_output` returns a non-zero exit status.
188
189 .. attribute:: returncode
190
Gregory P. Smith ext:(%20%5BGoogle%20Inc.%5D)583a1d62016-06-03 00:31:21 +0000191 Exit status of the child process. If the process exited due to a
192 signal, this will be the negative signal number.
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300193
194 .. attribute:: cmd
195
196 Command that was used to spawn the child process.
197
198 .. attribute:: output
199
Gregory P. Smith6e730002015-04-14 16:14:25 -0700200 Output of the child process if it was captured by :func:`run` or
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300201 :func:`check_output`. Otherwise, ``None``.
202
Gregory P. Smith6e730002015-04-14 16:14:25 -0700203 .. attribute:: stdout
204
205 Alias for output, for symmetry with :attr:`stderr`.
206
207 .. attribute:: stderr
208
209 Stderr output of the child process if it was captured by :func:`run`.
210 Otherwise, ``None``.
211
212 .. versionchanged:: 3.5
213 *stdout* and *stderr* attributes added
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300214
215
Nick Coghlanc29248f2011-11-08 20:49:23 +1000216.. _frequently-used-arguments:
217
218Frequently Used Arguments
219^^^^^^^^^^^^^^^^^^^^^^^^^
220
221To support a wide variety of use cases, the :class:`Popen` constructor (and
222the convenience functions) accept a large number of optional arguments. For
223most typical use cases, many of these arguments can be safely left at their
224default values. The arguments that are most commonly needed are:
225
226 *args* is required for all calls and should be a string, or a sequence of
227 program arguments. Providing a sequence of arguments is generally
228 preferred, as it allows the module to take care of any required escaping
229 and quoting of arguments (e.g. to permit spaces in file names). If passing
230 a single string, either *shell* must be :const:`True` (see below) or else
231 the string must simply name the program to be executed without specifying
232 any arguments.
233
234 *stdin*, *stdout* and *stderr* specify the executed program's standard input,
235 standard output and standard error file handles, respectively. Valid values
Nick Coghlan217f05b2011-11-08 22:11:21 +1000236 are :data:`PIPE`, :data:`DEVNULL`, an existing file descriptor (a positive
237 integer), an existing file object, and ``None``. :data:`PIPE` indicates
238 that a new pipe to the child should be created. :data:`DEVNULL` indicates
239 that the special file :data:`os.devnull` will be used. With the default
240 settings of ``None``, no redirection will occur; the child's file handles
241 will be inherited from the parent. Additionally, *stderr* can be
242 :data:`STDOUT`, which indicates that the stderr data from the child
243 process should be captured into the same file handle as for *stdout*.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000244
R David Murray1b00f252012-08-15 10:43:58 -0400245 .. index::
246 single: universal newlines; subprocess module
247
Ronald Oussoren385521c2013-07-07 09:26:45 +0200248 If *universal_newlines* is ``False`` the file objects *stdin*, *stdout* and
249 *stderr* will be opened as binary streams, and no line ending conversion is
250 done.
251
252 If *universal_newlines* is ``True``, these file objects
253 will be opened as text streams in :term:`universal newlines` mode
R David Murray0689ce42012-08-15 11:13:31 -0400254 using the encoding returned by :func:`locale.getpreferredencoding(False)
Ronald Oussoren385521c2013-07-07 09:26:45 +0200255 <locale.getpreferredencoding>`. For *stdin*, line ending characters
R David Murray0689ce42012-08-15 11:13:31 -0400256 ``'\n'`` in the input will be converted to the default line separator
257 :data:`os.linesep`. For *stdout* and *stderr*, all line endings in the
258 output will be converted to ``'\n'``. For more information see the
259 documentation of the :class:`io.TextIOWrapper` class when the *newline*
260 argument to its constructor is ``None``.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000261
Andrew Svetlov50be4522012-08-13 22:09:04 +0300262 .. note::
263
Gregory P. Smith1f8a40b2013-03-20 18:32:03 -0700264 The newlines attribute of the file objects :attr:`Popen.stdin`,
265 :attr:`Popen.stdout` and :attr:`Popen.stderr` are not updated by
266 the :meth:`Popen.communicate` method.
Andrew Svetlov50be4522012-08-13 22:09:04 +0300267
268 If *shell* is ``True``, the specified command will be executed through
Ezio Melotti186d5232012-09-15 08:34:08 +0300269 the shell. This can be useful if you are using Python primarily for the
Nick Coghlanc29248f2011-11-08 20:49:23 +1000270 enhanced control flow it offers over most system shells and still want
Ezio Melotti186d5232012-09-15 08:34:08 +0300271 convenient access to other shell features such as shell pipes, filename
272 wildcards, environment variable expansion, and expansion of ``~`` to a
273 user's home directory. However, note that Python itself offers
274 implementations of many shell-like features (in particular, :mod:`glob`,
275 :mod:`fnmatch`, :func:`os.walk`, :func:`os.path.expandvars`,
276 :func:`os.path.expanduser`, and :mod:`shutil`).
Nick Coghlanc29248f2011-11-08 20:49:23 +1000277
Andrew Svetlov4805fa82012-08-13 22:11:14 +0300278 .. versionchanged:: 3.3
279 When *universal_newlines* is ``True``, the class uses the encoding
280 :func:`locale.getpreferredencoding(False) <locale.getpreferredencoding>`
281 instead of ``locale.getpreferredencoding()``. See the
282 :class:`io.TextIOWrapper` class for more information on this change.
283
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700284 .. note::
Nick Coghlanc29248f2011-11-08 20:49:23 +1000285
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700286 Read the `Security Considerations`_ section before using ``shell=True``.
Andrew Svetlovc2415eb2012-10-28 11:42:26 +0200287
Nick Coghlanc29248f2011-11-08 20:49:23 +1000288These options, along with all of the other options, are described in more
289detail in the :class:`Popen` constructor documentation.
290
291
Sandro Tosi1526ad12011-12-25 11:27:37 +0100292Popen Constructor
Sandro Tosi3e6c8142011-12-25 17:14:11 +0100293^^^^^^^^^^^^^^^^^
Nick Coghlanc29248f2011-11-08 20:49:23 +1000294
295The underlying process creation and management in this module is handled by
296the :class:`Popen` class. It offers a lot of flexibility so that developers
297are able to handle the less common cases not covered by the convenience
298functions.
Georg Brandl116aa622007-08-15 14:28:22 +0000299
300
Gregory P. Smitha1ed5392013-03-23 11:44:25 -0700301.. class:: Popen(args, bufsize=-1, executable=None, stdin=None, stdout=None, \
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700302 stderr=None, preexec_fn=None, close_fds=True, shell=False, \
303 cwd=None, env=None, universal_newlines=False, \
304 startupinfo=None, creationflags=0, restore_signals=True, \
305 start_new_session=False, pass_fds=())
Georg Brandl116aa622007-08-15 14:28:22 +0000306
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700307 Execute a child program in a new process. On POSIX, the class uses
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700308 :meth:`os.execvp`-like behavior to execute the child program. On Windows,
309 the class uses the Windows ``CreateProcess()`` function. The arguments to
310 :class:`Popen` are as follows.
Georg Brandl116aa622007-08-15 14:28:22 +0000311
Chris Jerdonek470ee392012-10-08 23:06:57 -0700312 *args* should be a sequence of program arguments or else a single string.
313 By default, the program to execute is the first item in *args* if *args* is
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700314 a sequence. If *args* is a string, the interpretation is
315 platform-dependent and described below. See the *shell* and *executable*
316 arguments for additional differences from the default behavior. Unless
317 otherwise stated, it is recommended to pass *args* as a sequence.
Georg Brandl116aa622007-08-15 14:28:22 +0000318
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700319 On POSIX, if *args* is a string, the string is interpreted as the name or
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700320 path of the program to execute. However, this can only be done if not
321 passing arguments to the program.
Georg Brandl116aa622007-08-15 14:28:22 +0000322
R. David Murray5973e4d2010-02-04 16:41:57 +0000323 .. note::
324
325 :meth:`shlex.split` can be useful when determining the correct
326 tokenization for *args*, especially in complex cases::
327
328 >>> import shlex, subprocess
R. David Murray73bc75b2010-02-05 16:25:12 +0000329 >>> command_line = input()
R. David Murray5973e4d2010-02-04 16:41:57 +0000330 /bin/vikings -input eggs.txt -output "spam spam.txt" -cmd "echo '$MONEY'"
331 >>> args = shlex.split(command_line)
332 >>> print(args)
333 ['/bin/vikings', '-input', 'eggs.txt', '-output', 'spam spam.txt', '-cmd', "echo '$MONEY'"]
334 >>> p = subprocess.Popen(args) # Success!
335
336 Note in particular that options (such as *-input*) and arguments (such
337 as *eggs.txt*) that are separated by whitespace in the shell go in separate
338 list elements, while arguments that need quoting or backslash escaping when
339 used in the shell (such as filenames containing spaces or the *echo* command
340 shown above) are single list elements.
341
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700342 On Windows, if *args* is a sequence, it will be converted to a string in a
343 manner described in :ref:`converting-argument-sequence`. This is because
344 the underlying ``CreateProcess()`` operates on strings.
Chris Jerdonek470ee392012-10-08 23:06:57 -0700345
346 The *shell* argument (which defaults to *False*) specifies whether to use
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700347 the shell as the program to execute. If *shell* is *True*, it is
348 recommended to pass *args* as a string rather than as a sequence.
Chris Jerdonek470ee392012-10-08 23:06:57 -0700349
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700350 On POSIX with ``shell=True``, the shell defaults to :file:`/bin/sh`. If
Chris Jerdonek470ee392012-10-08 23:06:57 -0700351 *args* is a string, the string specifies the command
352 to execute through the shell. This means that the string must be
R. David Murray5973e4d2010-02-04 16:41:57 +0000353 formatted exactly as it would be when typed at the shell prompt. This
354 includes, for example, quoting or backslash escaping filenames with spaces in
355 them. If *args* is a sequence, the first item specifies the command string, and
356 any additional items will be treated as additional arguments to the shell
Chris Jerdonek470ee392012-10-08 23:06:57 -0700357 itself. That is to say, :class:`Popen` does the equivalent of::
R. David Murray5973e4d2010-02-04 16:41:57 +0000358
359 Popen(['/bin/sh', '-c', args[0], args[1], ...])
Georg Brandl116aa622007-08-15 14:28:22 +0000360
Chris Jerdonek470ee392012-10-08 23:06:57 -0700361 On Windows with ``shell=True``, the :envvar:`COMSPEC` environment variable
362 specifies the default shell. The only time you need to specify
363 ``shell=True`` on Windows is when the command you wish to execute is built
364 into the shell (e.g. :command:`dir` or :command:`copy`). You do not need
365 ``shell=True`` to run a batch file or console-based executable.
Georg Brandl116aa622007-08-15 14:28:22 +0000366
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700367 .. note::
Chris Jerdonekcc32a682012-10-10 22:52:22 -0700368
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700369 Read the `Security Considerations`_ section before using ``shell=True``.
Chris Jerdonekcc32a682012-10-10 22:52:22 -0700370
Antoine Pitrouafe8d062014-09-21 21:10:56 +0200371 *bufsize* will be supplied as the corresponding argument to the
372 :func:`open` function when creating the stdin/stdout/stderr pipe
373 file objects:
374
375 - :const:`0` means unbuffered (read and write are one
376 system call and can return short)
377 - :const:`1` means line buffered
378 (only usable if ``universal_newlines=True`` i.e., in a text mode)
379 - any other positive value means use a buffer of approximately that
380 size
381 - negative bufsize (the default) means the system default of
382 io.DEFAULT_BUFFER_SIZE will be used.
Georg Brandl116aa622007-08-15 14:28:22 +0000383
Georg Brandl37b70bb2013-11-25 08:48:37 +0100384 .. versionchanged:: 3.3.1
Gregory P. Smitha1ed5392013-03-23 11:44:25 -0700385 *bufsize* now defaults to -1 to enable buffering by default to match the
Georg Brandl37b70bb2013-11-25 08:48:37 +0100386 behavior that most code expects. In versions prior to Python 3.2.4 and
387 3.3.1 it incorrectly defaulted to :const:`0` which was unbuffered
388 and allowed short reads. This was unintentional and did not match the
389 behavior of Python 2 as most code expected.
Antoine Pitrou4b876202010-06-02 17:10:49 +0000390
Chris Jerdonek470ee392012-10-08 23:06:57 -0700391 The *executable* argument specifies a replacement program to execute. It
392 is very seldom needed. When ``shell=False``, *executable* replaces the
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700393 program to execute specified by *args*. However, the original *args* is
394 still passed to the program. Most programs treat the program specified
395 by *args* as the command name, which can then be different from the program
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700396 actually executed. On POSIX, the *args* name
Chris Jerdonek470ee392012-10-08 23:06:57 -0700397 becomes the display name for the executable in utilities such as
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700398 :program:`ps`. If ``shell=True``, on POSIX the *executable* argument
Chris Jerdonek470ee392012-10-08 23:06:57 -0700399 specifies a replacement shell for the default :file:`/bin/sh`.
Georg Brandl116aa622007-08-15 14:28:22 +0000400
Nick Coghlanc29248f2011-11-08 20:49:23 +1000401 *stdin*, *stdout* and *stderr* specify the executed program's standard input,
Georg Brandlaf265f42008-12-07 15:06:20 +0000402 standard output and standard error file handles, respectively. Valid values
Ross Lagerwallba102ec2011-03-16 18:40:25 +0200403 are :data:`PIPE`, :data:`DEVNULL`, an existing file descriptor (a positive
404 integer), an existing :term:`file object`, and ``None``. :data:`PIPE`
405 indicates that a new pipe to the child should be created. :data:`DEVNULL`
Nick Coghlan217f05b2011-11-08 22:11:21 +1000406 indicates that the special file :data:`os.devnull` will be used. With the
407 default settings of ``None``, no redirection will occur; the child's file
408 handles will be inherited from the parent. Additionally, *stderr* can be
409 :data:`STDOUT`, which indicates that the stderr data from the applications
410 should be captured into the same file handle as for stdout.
Georg Brandl116aa622007-08-15 14:28:22 +0000411
412 If *preexec_fn* is set to a callable object, this object will be called in the
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000413 child process just before the child is executed.
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700414 (POSIX only)
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000415
416 .. warning::
417
418 The *preexec_fn* parameter is not safe to use in the presence of threads
419 in your application. The child process could deadlock before exec is
420 called.
421 If you must use it, keep it trivial! Minimize the number of libraries
422 you call into.
423
424 .. note::
425
426 If you need to modify the environment for the child use the *env*
427 parameter rather than doing it in a *preexec_fn*.
428 The *start_new_session* parameter can take the place of a previously
429 common use of *preexec_fn* to call os.setsid() in the child.
Georg Brandl116aa622007-08-15 14:28:22 +0000430
431 If *close_fds* is true, all file descriptors except :const:`0`, :const:`1` and
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700432 :const:`2` will be closed before the child process is executed. (POSIX only).
433 The default varies by platform: Always true on POSIX. On Windows it is
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000434 true when *stdin*/*stdout*/*stderr* are :const:`None`, false otherwise.
Gregory P. Smithd23047b2010-12-04 09:10:44 +0000435 On Windows, if *close_fds* is true then no handles will be inherited by the
Georg Brandl116aa622007-08-15 14:28:22 +0000436 child process. Note that on Windows, you cannot set *close_fds* to true and
437 also redirect the standard handles by setting *stdin*, *stdout* or *stderr*.
438
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000439 .. versionchanged:: 3.2
440 The default for *close_fds* was changed from :const:`False` to
441 what is described above.
442
443 *pass_fds* is an optional sequence of file descriptors to keep open
444 between the parent and child. Providing any *pass_fds* forces
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700445 *close_fds* to be :const:`True`. (POSIX only)
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000446
447 .. versionadded:: 3.2
448 The *pass_fds* parameter was added.
Georg Brandl116aa622007-08-15 14:28:22 +0000449
Chris Jerdonekec3ea942012-09-30 00:10:28 -0700450 If *cwd* is not ``None``, the function changes the working directory to
451 *cwd* before executing the child. In particular, the function looks for
452 *executable* (or for the first item in *args*) relative to *cwd* if the
453 executable path is a relative path.
Georg Brandl116aa622007-08-15 14:28:22 +0000454
Serhiy Storchakafbc1c262013-11-29 12:17:13 +0200455 If *restore_signals* is true (the default) all signals that Python has set to
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000456 SIG_IGN are restored to SIG_DFL in the child process before the exec.
457 Currently this includes the SIGPIPE, SIGXFZ and SIGXFSZ signals.
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700458 (POSIX only)
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000459
460 .. versionchanged:: 3.2
461 *restore_signals* was added.
462
Serhiy Storchakafbc1c262013-11-29 12:17:13 +0200463 If *start_new_session* is true the setsid() system call will be made in the
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700464 child process prior to the execution of the subprocess. (POSIX only)
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000465
466 .. versionchanged:: 3.2
467 *start_new_session* was added.
468
Christian Heimesa342c012008-04-20 21:01:16 +0000469 If *env* is not ``None``, it must be a mapping that defines the environment
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000470 variables for the new process; these are used instead of the default
471 behavior of inheriting the current process' environment.
Georg Brandl116aa622007-08-15 14:28:22 +0000472
R. David Murray1055e892009-04-16 18:15:32 +0000473 .. note::
R. David Murrayf4ac1492009-04-15 22:35:15 +0000474
Georg Brandl2708f3a2009-12-20 14:38:23 +0000475 If specified, *env* must provide any variables required for the program to
476 execute. On Windows, in order to run a `side-by-side assembly`_ the
477 specified *env* **must** include a valid :envvar:`SystemRoot`.
R. David Murrayf4ac1492009-04-15 22:35:15 +0000478
Georg Brandl5d941342016-02-26 19:37:12 +0100479 .. _side-by-side assembly: https://en.wikipedia.org/wiki/Side-by-Side_Assembly
R. David Murray1055e892009-04-16 18:15:32 +0000480
Andrew Svetlov50be4522012-08-13 22:09:04 +0300481 If *universal_newlines* is ``True``, the file objects *stdin*, *stdout*
R David Murray1b00f252012-08-15 10:43:58 -0400482 and *stderr* are opened as text streams in universal newlines mode, as
Ronald Oussorena6865052013-07-06 10:23:59 +0200483 described above in :ref:`frequently-used-arguments`, otherwise they are
484 opened as binary streams.
Georg Brandl116aa622007-08-15 14:28:22 +0000485
Brian Curtine6242d72011-04-29 22:17:51 -0500486 If given, *startupinfo* will be a :class:`STARTUPINFO` object, which is
487 passed to the underlying ``CreateProcess`` function.
Brian Curtin30401932011-04-29 22:20:57 -0500488 *creationflags*, if given, can be :data:`CREATE_NEW_CONSOLE` or
489 :data:`CREATE_NEW_PROCESS_GROUP`. (Windows only)
Georg Brandl116aa622007-08-15 14:28:22 +0000490
Gregory P. Smith6b657452011-05-11 21:42:08 -0700491 Popen objects are supported as context managers via the :keyword:`with` statement:
492 on exit, standard file descriptors are closed, and the process is waited for.
Brian Curtin79cdb662010-12-03 02:46:02 +0000493 ::
494
495 with Popen(["ifconfig"], stdout=PIPE) as proc:
496 log.write(proc.stdout.read())
497
498 .. versionchanged:: 3.2
499 Added context manager support.
500
Georg Brandl116aa622007-08-15 14:28:22 +0000501
Georg Brandl116aa622007-08-15 14:28:22 +0000502Exceptions
503^^^^^^^^^^
504
505Exceptions raised in the child process, before the new program has started to
506execute, will be re-raised in the parent. Additionally, the exception object
507will have one extra attribute called :attr:`child_traceback`, which is a string
Georg Brandl81675612010-08-26 14:30:56 +0000508containing traceback information from the child's point of view.
Georg Brandl116aa622007-08-15 14:28:22 +0000509
510The most common exception raised is :exc:`OSError`. This occurs, for example,
511when trying to execute a non-existent file. Applications should prepare for
512:exc:`OSError` exceptions.
513
514A :exc:`ValueError` will be raised if :class:`Popen` is called with invalid
515arguments.
516
Nick Coghlanc29248f2011-11-08 20:49:23 +1000517:func:`check_call` and :func:`check_output` will raise
518:exc:`CalledProcessError` if the called process returns a non-zero return
519code.
Georg Brandl116aa622007-08-15 14:28:22 +0000520
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400521All of the functions and methods that accept a *timeout* parameter, such as
522:func:`call` and :meth:`Popen.communicate` will raise :exc:`TimeoutExpired` if
523the timeout expires before the process exits.
524
Ronald Oussorenc1577902011-03-16 10:03:10 -0400525Exceptions defined in this module all inherit from :exc:`SubprocessError`.
Gregory P. Smith54d412e2011-03-14 14:08:43 -0400526
527 .. versionadded:: 3.3
528 The :exc:`SubprocessError` base class was added.
529
Georg Brandl116aa622007-08-15 14:28:22 +0000530
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700531Security Considerations
532-----------------------
Georg Brandl116aa622007-08-15 14:28:22 +0000533
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700534Unlike some other popen functions, this implementation will never
535implicitly call a system shell. This means that all characters,
536including shell metacharacters, can safely be passed to child processes.
537If the shell is invoked explicitly, via ``shell=True``, it is the application's
538responsibility to ensure that all whitespace and metacharacters are
539quoted appropriately to avoid
Georg Brandl5d941342016-02-26 19:37:12 +0100540`shell injection <https://en.wikipedia.org/wiki/Shell_injection#Shell_injection>`_
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700541vulnerabilities.
542
543When using ``shell=True``, the :func:`shlex.quote` function can be
544used to properly escape whitespace and shell metacharacters in strings
545that are going to be used to construct shell commands.
Georg Brandl116aa622007-08-15 14:28:22 +0000546
547
548Popen Objects
549-------------
550
551Instances of the :class:`Popen` class have the following methods:
552
553
554.. method:: Popen.poll()
555
Serhiy Storchaka9e0ae532013-08-24 00:23:38 +0300556 Check if child process has terminated. Set and return
557 :attr:`~Popen.returncode` attribute.
Georg Brandl116aa622007-08-15 14:28:22 +0000558
559
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400560.. method:: Popen.wait(timeout=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000561
Serhiy Storchaka9e0ae532013-08-24 00:23:38 +0300562 Wait for child process to terminate. Set and return
563 :attr:`~Popen.returncode` attribute.
Georg Brandl116aa622007-08-15 14:28:22 +0000564
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400565 If the process does not terminate after *timeout* seconds, raise a
566 :exc:`TimeoutExpired` exception. It is safe to catch this exception and
567 retry the wait.
568
Victor Stinner07171242014-02-24 13:18:47 +0100569 .. note::
570
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700571 This will deadlock when using ``stdout=PIPE`` or ``stderr=PIPE``
572 and the child process generates enough output to a pipe such that
573 it blocks waiting for the OS pipe buffer to accept more data.
574 Use :meth:`Popen.communicate` when using pipes to avoid that.
575
576 .. note::
577
Victor Stinner07171242014-02-24 13:18:47 +0100578 The function is implemented using a busy loop (non-blocking call and
579 short sleeps). Use the :mod:`asyncio` module for an asynchronous wait:
580 see :class:`asyncio.create_subprocess_exec`.
581
Reid Kleckner28f13032011-03-14 12:36:53 -0400582 .. versionchanged:: 3.3
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400583 *timeout* was added.
Georg Brandl116aa622007-08-15 14:28:22 +0000584
Gregory P. Smithbbe33352014-02-11 09:21:03 -0800585 .. deprecated:: 3.4
586
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700587 Do not use the *endtime* parameter. It is was unintentionally
588 exposed in 3.3 but was left undocumented as it was intended to be
589 private for internal use. Use *timeout* instead.
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400590
591.. method:: Popen.communicate(input=None, timeout=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000592
593 Interact with process: Send data to stdin. Read data from stdout and stderr,
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400594 until end-of-file is reached. Wait for process to terminate. The optional
Gregory P. Smitha454ef62011-05-22 22:29:49 -0700595 *input* argument should be data to be sent to the child process, or
596 ``None``, if no data should be sent to the child. The type of *input*
597 must be bytes or, if *universal_newlines* was ``True``, a string.
Georg Brandl116aa622007-08-15 14:28:22 +0000598
Victor Stinner39892052014-10-14 00:52:07 +0200599 :meth:`communicate` returns a tuple ``(stdout_data, stderr_data)``.
Andrew Kuchling4f7b0c32014-04-14 15:08:18 -0400600 The data will be bytes or, if *universal_newlines* was ``True``, strings.
Georg Brandl116aa622007-08-15 14:28:22 +0000601
Guido van Rossum0d3fb8a2007-11-26 23:23:18 +0000602 Note that if you want to send data to the process's stdin, you need to create
603 the Popen object with ``stdin=PIPE``. Similarly, to get anything other than
604 ``None`` in the result tuple, you need to give ``stdout=PIPE`` and/or
605 ``stderr=PIPE`` too.
606
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400607 If the process does not terminate after *timeout* seconds, a
608 :exc:`TimeoutExpired` exception will be raised. Catching this exception and
609 retrying communication will not lose any output.
610
611 The child process is not killed if the timeout expires, so in order to
612 cleanup properly a well-behaved application should kill the child process and
613 finish communication::
614
615 proc = subprocess.Popen(...)
616 try:
617 outs, errs = proc.communicate(timeout=15)
618 except TimeoutExpired:
619 proc.kill()
620 outs, errs = proc.communicate()
621
Christian Heimes7f044312008-01-06 17:05:40 +0000622 .. note::
Georg Brandl116aa622007-08-15 14:28:22 +0000623
Christian Heimes7f044312008-01-06 17:05:40 +0000624 The data read is buffered in memory, so do not use this method if the data
625 size is large or unlimited.
626
Reid Kleckner28f13032011-03-14 12:36:53 -0400627 .. versionchanged:: 3.3
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400628 *timeout* was added.
629
Georg Brandl116aa622007-08-15 14:28:22 +0000630
Christian Heimesa342c012008-04-20 21:01:16 +0000631.. method:: Popen.send_signal(signal)
632
633 Sends the signal *signal* to the child.
634
635 .. note::
636
Brian Curtineb24d742010-04-12 17:16:38 +0000637 On Windows, SIGTERM is an alias for :meth:`terminate`. CTRL_C_EVENT and
Senthil Kumaran916bd382010-10-15 12:55:19 +0000638 CTRL_BREAK_EVENT can be sent to processes started with a *creationflags*
Brian Curtineb24d742010-04-12 17:16:38 +0000639 parameter which includes `CREATE_NEW_PROCESS_GROUP`.
Christian Heimesa342c012008-04-20 21:01:16 +0000640
Christian Heimesa342c012008-04-20 21:01:16 +0000641
642.. method:: Popen.terminate()
643
644 Stop the child. On Posix OSs the method sends SIGTERM to the
Georg Brandl60203b42010-10-06 10:11:56 +0000645 child. On Windows the Win32 API function :c:func:`TerminateProcess` is called
Christian Heimesa342c012008-04-20 21:01:16 +0000646 to stop the child.
647
Christian Heimesa342c012008-04-20 21:01:16 +0000648
649.. method:: Popen.kill()
650
651 Kills the child. On Posix OSs the function sends SIGKILL to the child.
652 On Windows :meth:`kill` is an alias for :meth:`terminate`.
653
Christian Heimesa342c012008-04-20 21:01:16 +0000654
Georg Brandl116aa622007-08-15 14:28:22 +0000655The following attributes are also available:
656
Gregory P. Smith024c5ee2014-04-29 11:33:23 -0700657.. attribute:: Popen.args
658
659 The *args* argument as it was passed to :class:`Popen` -- a
660 sequence of program arguments or else a single string.
661
662 .. versionadded:: 3.3
Georg Brandl734e2682008-08-12 08:18:18 +0000663
Georg Brandl116aa622007-08-15 14:28:22 +0000664.. attribute:: Popen.stdin
665
Benjamin Peterson3d8814e2014-01-18 00:45:56 -0500666 If the *stdin* argument was :data:`PIPE`, this attribute is a writeable
667 stream object as returned by :func:`open`. If the *universal_newlines*
668 argument was ``True``, the stream is a text stream, otherwise it is a byte
669 stream. If the *stdin* argument was not :data:`PIPE`, this attribute is
670 ``None``.
Georg Brandl116aa622007-08-15 14:28:22 +0000671
672
673.. attribute:: Popen.stdout
674
Benjamin Peterson3d8814e2014-01-18 00:45:56 -0500675 If the *stdout* argument was :data:`PIPE`, this attribute is a readable
676 stream object as returned by :func:`open`. Reading from the stream provides
677 output from the child process. If the *universal_newlines* argument was
678 ``True``, the stream is a text stream, otherwise it is a byte stream. If the
679 *stdout* argument was not :data:`PIPE`, this attribute is ``None``.
Benjamin Petersonaf69fe22014-01-18 00:49:04 -0500680
Georg Brandl116aa622007-08-15 14:28:22 +0000681
682.. attribute:: Popen.stderr
683
Benjamin Peterson3d8814e2014-01-18 00:45:56 -0500684 If the *stderr* argument was :data:`PIPE`, this attribute is a readable
685 stream object as returned by :func:`open`. Reading from the stream provides
686 error output from the child process. If the *universal_newlines* argument was
687 ``True``, the stream is a text stream, otherwise it is a byte stream. If the
688 *stderr* argument was not :data:`PIPE`, this attribute is ``None``.
Georg Brandl116aa622007-08-15 14:28:22 +0000689
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700690.. warning::
691
692 Use :meth:`~Popen.communicate` rather than :attr:`.stdin.write <Popen.stdin>`,
693 :attr:`.stdout.read <Popen.stdout>` or :attr:`.stderr.read <Popen.stderr>` to avoid
694 deadlocks due to any of the other OS pipe buffers filling up and blocking the
695 child process.
696
Georg Brandl116aa622007-08-15 14:28:22 +0000697
698.. attribute:: Popen.pid
699
700 The process ID of the child process.
701
Georg Brandl58bfdca2010-03-21 09:50:49 +0000702 Note that if you set the *shell* argument to ``True``, this is the process ID
703 of the spawned shell.
704
Georg Brandl116aa622007-08-15 14:28:22 +0000705
706.. attribute:: Popen.returncode
707
Christian Heimes7f044312008-01-06 17:05:40 +0000708 The child return code, set by :meth:`poll` and :meth:`wait` (and indirectly
709 by :meth:`communicate`). A ``None`` value indicates that the process
710 hasn't terminated yet.
Georg Brandl48310cd2009-01-03 21:18:54 +0000711
Christian Heimes7f044312008-01-06 17:05:40 +0000712 A negative value ``-N`` indicates that the child was terminated by signal
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700713 ``N`` (POSIX only).
Georg Brandl116aa622007-08-15 14:28:22 +0000714
715
Brian Curtine6242d72011-04-29 22:17:51 -0500716Windows Popen Helpers
717---------------------
718
719The :class:`STARTUPINFO` class and following constants are only available
720on Windows.
721
722.. class:: STARTUPINFO()
Brian Curtin73365dd2011-04-29 22:18:33 -0500723
Brian Curtine6242d72011-04-29 22:17:51 -0500724 Partial support of the Windows
Georg Brandl5d941342016-02-26 19:37:12 +0100725 `STARTUPINFO <https://msdn.microsoft.com/en-us/library/ms686331(v=vs.85).aspx>`__
Brian Curtine6242d72011-04-29 22:17:51 -0500726 structure is used for :class:`Popen` creation.
727
728 .. attribute:: dwFlags
729
Senthil Kumarana6bac952011-07-04 11:28:30 -0700730 A bit field that determines whether certain :class:`STARTUPINFO`
731 attributes are used when the process creates a window. ::
Brian Curtine6242d72011-04-29 22:17:51 -0500732
733 si = subprocess.STARTUPINFO()
734 si.dwFlags = subprocess.STARTF_USESTDHANDLES | subprocess.STARTF_USESHOWWINDOW
735
736 .. attribute:: hStdInput
737
Senthil Kumarana6bac952011-07-04 11:28:30 -0700738 If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
739 is the standard input handle for the process. If
740 :data:`STARTF_USESTDHANDLES` is not specified, the default for standard
741 input is the keyboard buffer.
Brian Curtine6242d72011-04-29 22:17:51 -0500742
743 .. attribute:: hStdOutput
744
Senthil Kumarana6bac952011-07-04 11:28:30 -0700745 If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
746 is the standard output handle for the process. Otherwise, this attribute
747 is ignored and the default for standard output is the console window's
Brian Curtine6242d72011-04-29 22:17:51 -0500748 buffer.
749
750 .. attribute:: hStdError
751
Senthil Kumarana6bac952011-07-04 11:28:30 -0700752 If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
753 is the standard error handle for the process. Otherwise, this attribute is
Brian Curtine6242d72011-04-29 22:17:51 -0500754 ignored and the default for standard error is the console window's buffer.
755
756 .. attribute:: wShowWindow
757
Senthil Kumarana6bac952011-07-04 11:28:30 -0700758 If :attr:`dwFlags` specifies :data:`STARTF_USESHOWWINDOW`, this attribute
Brian Curtine6242d72011-04-29 22:17:51 -0500759 can be any of the values that can be specified in the ``nCmdShow``
760 parameter for the
Georg Brandl5d941342016-02-26 19:37:12 +0100761 `ShowWindow <https://msdn.microsoft.com/en-us/library/ms633548(v=vs.85).aspx>`__
Senthil Kumarana6bac952011-07-04 11:28:30 -0700762 function, except for ``SW_SHOWDEFAULT``. Otherwise, this attribute is
Brian Curtine6242d72011-04-29 22:17:51 -0500763 ignored.
Brian Curtin73365dd2011-04-29 22:18:33 -0500764
Brian Curtine6242d72011-04-29 22:17:51 -0500765 :data:`SW_HIDE` is provided for this attribute. It is used when
766 :class:`Popen` is called with ``shell=True``.
767
768
769Constants
770^^^^^^^^^
771
772The :mod:`subprocess` module exposes the following constants.
773
774.. data:: STD_INPUT_HANDLE
775
776 The standard input device. Initially, this is the console input buffer,
777 ``CONIN$``.
778
779.. data:: STD_OUTPUT_HANDLE
780
781 The standard output device. Initially, this is the active console screen
782 buffer, ``CONOUT$``.
783
784.. data:: STD_ERROR_HANDLE
785
786 The standard error device. Initially, this is the active console screen
787 buffer, ``CONOUT$``.
788
789.. data:: SW_HIDE
790
791 Hides the window. Another window will be activated.
792
793.. data:: STARTF_USESTDHANDLES
794
795 Specifies that the :attr:`STARTUPINFO.hStdInput`,
Senthil Kumarana6bac952011-07-04 11:28:30 -0700796 :attr:`STARTUPINFO.hStdOutput`, and :attr:`STARTUPINFO.hStdError` attributes
Brian Curtine6242d72011-04-29 22:17:51 -0500797 contain additional information.
798
799.. data:: STARTF_USESHOWWINDOW
800
Senthil Kumarana6bac952011-07-04 11:28:30 -0700801 Specifies that the :attr:`STARTUPINFO.wShowWindow` attribute contains
Brian Curtine6242d72011-04-29 22:17:51 -0500802 additional information.
803
804.. data:: CREATE_NEW_CONSOLE
805
806 The new process has a new console, instead of inheriting its parent's
807 console (the default).
Brian Curtin73365dd2011-04-29 22:18:33 -0500808
Brian Curtin30401932011-04-29 22:20:57 -0500809.. data:: CREATE_NEW_PROCESS_GROUP
810
811 A :class:`Popen` ``creationflags`` parameter to specify that a new process
812 group will be created. This flag is necessary for using :func:`os.kill`
813 on the subprocess.
814
815 This flag is ignored if :data:`CREATE_NEW_CONSOLE` is specified.
816
Gregory P. Smith6e730002015-04-14 16:14:25 -0700817.. _call-function-trio:
818
819Older high-level API
820--------------------
821
822Prior to Python 3.5, these three functions comprised the high level API to
823subprocess. You can now use :func:`run` in many cases, but lots of existing code
824calls these functions.
825
826.. function:: call(args, *, stdin=None, stdout=None, stderr=None, shell=False, timeout=None)
827
828 Run the command described by *args*. Wait for command to complete, then
Berker Peksagbf1d4b62015-07-25 14:27:07 +0300829 return the :attr:`~Popen.returncode` attribute.
Gregory P. Smith6e730002015-04-14 16:14:25 -0700830
831 This is equivalent to::
832
833 run(...).returncode
834
835 (except that the *input* and *check* parameters are not supported)
836
Berker Peksagbf1d4b62015-07-25 14:27:07 +0300837 The arguments shown above are merely the most
838 common ones. The full function signature is largely the
839 same as that of the :class:`Popen` constructor - this function passes all
840 supplied arguments other than *timeout* directly through to that interface.
841
Gregory P. Smith6e730002015-04-14 16:14:25 -0700842 .. note::
843
844 Do not use ``stdout=PIPE`` or ``stderr=PIPE`` with this
845 function. The child process will block if it generates enough
846 output to a pipe to fill up the OS pipe buffer as the pipes are
847 not being read from.
848
849 .. versionchanged:: 3.3
850 *timeout* was added.
851
852.. function:: check_call(args, *, stdin=None, stdout=None, stderr=None, shell=False, timeout=None)
853
854 Run command with arguments. Wait for command to complete. If the return
855 code was zero then return, otherwise raise :exc:`CalledProcessError`. The
856 :exc:`CalledProcessError` object will have the return code in the
857 :attr:`~CalledProcessError.returncode` attribute.
858
859 This is equivalent to::
860
861 run(..., check=True)
862
863 (except that the *input* parameter is not supported)
864
Berker Peksagbf1d4b62015-07-25 14:27:07 +0300865 The arguments shown above are merely the most
866 common ones. The full function signature is largely the
867 same as that of the :class:`Popen` constructor - this function passes all
868 supplied arguments other than *timeout* directly through to that interface.
869
Gregory P. Smith6e730002015-04-14 16:14:25 -0700870 .. note::
871
872 Do not use ``stdout=PIPE`` or ``stderr=PIPE`` with this
873 function. The child process will block if it generates enough
874 output to a pipe to fill up the OS pipe buffer as the pipes are
875 not being read from.
876
877 .. versionchanged:: 3.3
878 *timeout* was added.
879
880
Berker Peksagbf1d4b62015-07-25 14:27:07 +0300881.. function:: check_output(args, *, stdin=None, stderr=None, shell=False, universal_newlines=False, timeout=None)
Gregory P. Smith6e730002015-04-14 16:14:25 -0700882
883 Run command with arguments and return its output.
884
885 If the return code was non-zero it raises a :exc:`CalledProcessError`. The
886 :exc:`CalledProcessError` object will have the return code in the
887 :attr:`~CalledProcessError.returncode` attribute and any output in the
888 :attr:`~CalledProcessError.output` attribute.
889
890 This is equivalent to::
891
892 run(..., check=True, stdout=PIPE).stdout
893
Berker Peksagbf1d4b62015-07-25 14:27:07 +0300894 The arguments shown above are merely the most common ones.
895 The full function signature is largely the same as that of :func:`run` -
896 most arguments are passed directly through to that interface.
897 However, explicitly passing ``input=None`` to inherit the parent's
898 standard input file handle is not supported.
899
Gregory P. Smith6e730002015-04-14 16:14:25 -0700900 By default, this function will return the data as encoded bytes. The actual
901 encoding of the output data may depend on the command being invoked, so the
902 decoding to text will often need to be handled at the application level.
903
904 This behaviour may be overridden by setting *universal_newlines* to
905 ``True`` as described above in :ref:`frequently-used-arguments`.
906
907 To also capture standard error in the result, use
908 ``stderr=subprocess.STDOUT``::
909
910 >>> subprocess.check_output(
911 ... "ls non_existent_file; exit 0",
912 ... stderr=subprocess.STDOUT,
913 ... shell=True)
914 'ls: non_existent_file: No such file or directory\n'
915
916 .. versionadded:: 3.1
917
918 .. versionchanged:: 3.3
919 *timeout* was added.
920
921 .. versionchanged:: 3.4
Berker Peksagbf1d4b62015-07-25 14:27:07 +0300922 Support for the *input* keyword argument was added.
Brian Curtine6242d72011-04-29 22:17:51 -0500923
Benjamin Petersondcf97b92008-07-02 17:30:14 +0000924.. _subprocess-replacements:
925
Ezio Melotti402f75d2012-11-08 10:07:10 +0200926Replacing Older Functions with the :mod:`subprocess` Module
927-----------------------------------------------------------
Georg Brandl116aa622007-08-15 14:28:22 +0000928
Nick Coghlanc29248f2011-11-08 20:49:23 +1000929In this section, "a becomes b" means that b can be used as a replacement for a.
Georg Brandl116aa622007-08-15 14:28:22 +0000930
931.. note::
932
Nick Coghlanc29248f2011-11-08 20:49:23 +1000933 All "a" functions in this section fail (more or less) silently if the
934 executed program cannot be found; the "b" replacements raise :exc:`OSError`
935 instead.
Georg Brandl116aa622007-08-15 14:28:22 +0000936
Nick Coghlanc29248f2011-11-08 20:49:23 +1000937 In addition, the replacements using :func:`check_output` will fail with a
938 :exc:`CalledProcessError` if the requested operation produces a non-zero
Serhiy Storchaka9e0ae532013-08-24 00:23:38 +0300939 return code. The output is still available as the
940 :attr:`~CalledProcessError.output` attribute of the raised exception.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000941
942In the following examples, we assume that the relevant functions have already
Ezio Melotti402f75d2012-11-08 10:07:10 +0200943been imported from the :mod:`subprocess` module.
Georg Brandl116aa622007-08-15 14:28:22 +0000944
945
946Replacing /bin/sh shell backquote
947^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
948
949::
950
951 output=`mycmd myarg`
Nick Coghlanc29248f2011-11-08 20:49:23 +1000952 # becomes
953 output = check_output(["mycmd", "myarg"])
Georg Brandl116aa622007-08-15 14:28:22 +0000954
955
Benjamin Petersonf10a79a2008-10-11 00:49:57 +0000956Replacing shell pipeline
957^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +0000958
959::
960
961 output=`dmesg | grep hda`
Nick Coghlanc29248f2011-11-08 20:49:23 +1000962 # becomes
Georg Brandl116aa622007-08-15 14:28:22 +0000963 p1 = Popen(["dmesg"], stdout=PIPE)
964 p2 = Popen(["grep", "hda"], stdin=p1.stdout, stdout=PIPE)
Gregory P. Smithe09d2f12011-02-05 21:47:25 +0000965 p1.stdout.close() # Allow p1 to receive a SIGPIPE if p2 exits.
Georg Brandl116aa622007-08-15 14:28:22 +0000966 output = p2.communicate()[0]
967
Gregory P. Smithe09d2f12011-02-05 21:47:25 +0000968The p1.stdout.close() call after starting the p2 is important in order for p1
969to receive a SIGPIPE if p2 exits before p1.
Georg Brandl116aa622007-08-15 14:28:22 +0000970
Nick Coghlanc29248f2011-11-08 20:49:23 +1000971Alternatively, for trusted input, the shell's own pipeline support may still
R David Murray28b8b942012-04-03 08:46:48 -0400972be used directly::
Nick Coghlanc29248f2011-11-08 20:49:23 +1000973
974 output=`dmesg | grep hda`
975 # becomes
976 output=check_output("dmesg | grep hda", shell=True)
977
978
Benjamin Peterson87c8d872009-06-11 22:54:11 +0000979Replacing :func:`os.system`
980^^^^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +0000981
982::
983
984 sts = os.system("mycmd" + " myarg")
Nick Coghlanc29248f2011-11-08 20:49:23 +1000985 # becomes
986 sts = call("mycmd" + " myarg", shell=True)
Georg Brandl116aa622007-08-15 14:28:22 +0000987
988Notes:
989
990* Calling the program through the shell is usually not required.
991
Georg Brandl116aa622007-08-15 14:28:22 +0000992A more realistic example would look like this::
993
994 try:
995 retcode = call("mycmd" + " myarg", shell=True)
996 if retcode < 0:
Collin Winterc79461b2007-09-01 23:34:30 +0000997 print("Child was terminated by signal", -retcode, file=sys.stderr)
Georg Brandl116aa622007-08-15 14:28:22 +0000998 else:
Collin Winterc79461b2007-09-01 23:34:30 +0000999 print("Child returned", retcode, file=sys.stderr)
Georg Brandl116aa622007-08-15 14:28:22 +00001000 except OSError as e:
Collin Winterc79461b2007-09-01 23:34:30 +00001001 print("Execution failed:", e, file=sys.stderr)
Georg Brandl116aa622007-08-15 14:28:22 +00001002
1003
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001004Replacing the :func:`os.spawn <os.spawnl>` family
1005^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +00001006
1007P_NOWAIT example::
1008
1009 pid = os.spawnlp(os.P_NOWAIT, "/bin/mycmd", "mycmd", "myarg")
1010 ==>
1011 pid = Popen(["/bin/mycmd", "myarg"]).pid
1012
1013P_WAIT example::
1014
1015 retcode = os.spawnlp(os.P_WAIT, "/bin/mycmd", "mycmd", "myarg")
1016 ==>
1017 retcode = call(["/bin/mycmd", "myarg"])
1018
1019Vector example::
1020
1021 os.spawnvp(os.P_NOWAIT, path, args)
1022 ==>
1023 Popen([path] + args[1:])
1024
1025Environment example::
1026
1027 os.spawnlpe(os.P_NOWAIT, "/bin/mycmd", "mycmd", "myarg", env)
1028 ==>
1029 Popen(["/bin/mycmd", "myarg"], env={"PATH": "/usr/bin"})
1030
1031
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001032
1033Replacing :func:`os.popen`, :func:`os.popen2`, :func:`os.popen3`
1034^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +00001035
1036::
1037
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001038 (child_stdin, child_stdout) = os.popen2(cmd, mode, bufsize)
Georg Brandl116aa622007-08-15 14:28:22 +00001039 ==>
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001040 p = Popen(cmd, shell=True, bufsize=bufsize,
1041 stdin=PIPE, stdout=PIPE, close_fds=True)
1042 (child_stdin, child_stdout) = (p.stdin, p.stdout)
Georg Brandl116aa622007-08-15 14:28:22 +00001043
1044::
1045
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001046 (child_stdin,
1047 child_stdout,
1048 child_stderr) = os.popen3(cmd, mode, bufsize)
Georg Brandl116aa622007-08-15 14:28:22 +00001049 ==>
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001050 p = Popen(cmd, shell=True, bufsize=bufsize,
1051 stdin=PIPE, stdout=PIPE, stderr=PIPE, close_fds=True)
1052 (child_stdin,
1053 child_stdout,
1054 child_stderr) = (p.stdin, p.stdout, p.stderr)
1055
1056::
1057
1058 (child_stdin, child_stdout_and_stderr) = os.popen4(cmd, mode, bufsize)
1059 ==>
1060 p = Popen(cmd, shell=True, bufsize=bufsize,
1061 stdin=PIPE, stdout=PIPE, stderr=STDOUT, close_fds=True)
1062 (child_stdin, child_stdout_and_stderr) = (p.stdin, p.stdout)
1063
1064Return code handling translates as follows::
1065
1066 pipe = os.popen(cmd, 'w')
1067 ...
1068 rc = pipe.close()
Stefan Krahfc9e08d2010-07-14 10:16:11 +00001069 if rc is not None and rc >> 8:
Ezio Melotti985e24d2009-09-13 07:54:02 +00001070 print("There were some errors")
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001071 ==>
R David Murray17227a72015-09-04 10:01:19 -04001072 process = Popen(cmd, stdin=PIPE)
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001073 ...
1074 process.stdin.close()
1075 if process.wait() != 0:
Ezio Melotti985e24d2009-09-13 07:54:02 +00001076 print("There were some errors")
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001077
1078
1079Replacing functions from the :mod:`popen2` module
1080^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1081
1082.. note::
1083
1084 If the cmd argument to popen2 functions is a string, the command is executed
1085 through /bin/sh. If it is a list, the command is directly executed.
1086
1087::
1088
1089 (child_stdout, child_stdin) = popen2.popen2("somestring", bufsize, mode)
1090 ==>
R David Murrayae9d1932014-05-14 10:09:52 -04001091 p = Popen("somestring", shell=True, bufsize=bufsize,
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001092 stdin=PIPE, stdout=PIPE, close_fds=True)
1093 (child_stdout, child_stdin) = (p.stdout, p.stdin)
1094
1095::
1096
1097 (child_stdout, child_stdin) = popen2.popen2(["mycmd", "myarg"], bufsize, mode)
1098 ==>
1099 p = Popen(["mycmd", "myarg"], bufsize=bufsize,
1100 stdin=PIPE, stdout=PIPE, close_fds=True)
1101 (child_stdout, child_stdin) = (p.stdout, p.stdin)
1102
1103:class:`popen2.Popen3` and :class:`popen2.Popen4` basically work as
1104:class:`subprocess.Popen`, except that:
1105
1106* :class:`Popen` raises an exception if the execution fails.
1107
1108* the *capturestderr* argument is replaced with the *stderr* argument.
1109
1110* ``stdin=PIPE`` and ``stdout=PIPE`` must be specified.
1111
1112* popen2 closes all file descriptors by default, but you have to specify
Gregory P. Smithf5604852010-12-13 06:45:02 +00001113 ``close_fds=True`` with :class:`Popen` to guarantee this behavior on
1114 all platforms or past Python versions.
Eli Bendersky046a7642011-04-15 07:23:26 +03001115
Nick Coghlanc29248f2011-11-08 20:49:23 +10001116
Nick Coghlanc29248f2011-11-08 20:49:23 +10001117Legacy Shell Invocation Functions
Nick Coghlan32e4a582011-11-08 21:50:58 +10001118---------------------------------
Nick Coghlanc29248f2011-11-08 20:49:23 +10001119
1120This module also provides the following legacy functions from the 2.x
1121``commands`` module. These operations implicitly invoke the system shell and
1122none of the guarantees described above regarding security and exception
1123handling consistency are valid for these functions.
1124
1125.. function:: getstatusoutput(cmd)
1126
1127 Return ``(status, output)`` of executing *cmd* in a shell.
1128
Tim Golden60798142013-11-05 12:57:25 +00001129 Execute the string *cmd* in a shell with :meth:`Popen.check_output` and
1130 return a 2-tuple ``(status, output)``. Universal newlines mode is used;
1131 see the notes on :ref:`frequently-used-arguments` for more details.
Tim Golden3a2abb52013-11-03 18:24:50 +00001132
1133 A trailing newline is stripped from the output.
1134 The exit status for the command can be interpreted
Nick Coghlanc29248f2011-11-08 20:49:23 +10001135 according to the rules for the C function :c:func:`wait`. Example::
1136
1137 >>> subprocess.getstatusoutput('ls /bin/ls')
1138 (0, '/bin/ls')
1139 >>> subprocess.getstatusoutput('cat /bin/junk')
1140 (256, 'cat: /bin/junk: No such file or directory')
1141 >>> subprocess.getstatusoutput('/bin/junk')
1142 (256, 'sh: /bin/junk: not found')
1143
Gregory P. Smith8e0aa052014-05-11 13:28:35 -07001144 Availability: POSIX & Windows
R David Murray95b696a2014-03-07 20:04:17 -05001145
1146 .. versionchanged:: 3.3.4
1147 Windows support added
Nick Coghlanc29248f2011-11-08 20:49:23 +10001148
1149
1150.. function:: getoutput(cmd)
1151
1152 Return output (stdout and stderr) of executing *cmd* in a shell.
1153
1154 Like :func:`getstatusoutput`, except the exit status is ignored and the return
1155 value is a string containing the command's output. Example::
1156
1157 >>> subprocess.getoutput('ls /bin/ls')
1158 '/bin/ls'
1159
Gregory P. Smith8e0aa052014-05-11 13:28:35 -07001160 Availability: POSIX & Windows
R David Murray95b696a2014-03-07 20:04:17 -05001161
1162 .. versionchanged:: 3.3.4
1163 Windows support added
Nick Coghlanc29248f2011-11-08 20:49:23 +10001164
Nick Coghlan32e4a582011-11-08 21:50:58 +10001165
Eli Bendersky046a7642011-04-15 07:23:26 +03001166Notes
1167-----
1168
1169.. _converting-argument-sequence:
1170
1171Converting an argument sequence to a string on Windows
1172^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1173
1174On Windows, an *args* sequence is converted to a string that can be parsed
1175using the following rules (which correspond to the rules used by the MS C
1176runtime):
1177
11781. Arguments are delimited by white space, which is either a
1179 space or a tab.
1180
11812. A string surrounded by double quotation marks is
1182 interpreted as a single argument, regardless of white space
1183 contained within. A quoted string can be embedded in an
1184 argument.
1185
11863. A double quotation mark preceded by a backslash is
1187 interpreted as a literal double quotation mark.
1188
11894. Backslashes are interpreted literally, unless they
1190 immediately precede a double quotation mark.
1191
11925. If backslashes immediately precede a double quotation mark,
1193 every pair of backslashes is interpreted as a literal
1194 backslash. If the number of backslashes is odd, the last
1195 backslash escapes the next double quotation mark as
1196 described in rule 3.
1197
Eli Benderskyd2112312011-04-15 07:26:28 +03001198
Éric Araujo9bce3112011-07-27 18:29:31 +02001199.. seealso::
1200
1201 :mod:`shlex`
1202 Module which provides function to parse and escape command lines.