blob: ad49d7f201764989c02bf826a9646d0bac381142 [file] [log] [blame]
Georg Brandl116aa622007-08-15 14:28:22 +00001:mod:`subprocess` --- Subprocess management
2===========================================
3
4.. module:: subprocess
5 :synopsis: Subprocess management.
Terry Jan Reedyfa089b92016-06-11 15:02:54 -04006
Georg Brandl116aa622007-08-15 14:28:22 +00007.. moduleauthor:: Peter Åstrand <astrand@lysator.liu.se>
8.. sectionauthor:: Peter Åstrand <astrand@lysator.liu.se>
9
Terry Jan Reedyfa089b92016-06-11 15:02:54 -040010**Source code:** :source:`Lib/subprocess.py`
11
12--------------
Georg Brandl116aa622007-08-15 14:28:22 +000013
Georg Brandl116aa622007-08-15 14:28:22 +000014The :mod:`subprocess` module allows you to spawn new processes, connect to their
15input/output/error pipes, and obtain their return codes. This module intends to
Benjamin Peterson5eea8a72014-03-12 21:41:35 -050016replace several older modules and functions::
Georg Brandl116aa622007-08-15 14:28:22 +000017
18 os.system
19 os.spawn*
Georg Brandl116aa622007-08-15 14:28:22 +000020
21Information about how the :mod:`subprocess` module can be used to replace these
22modules and functions can be found in the following sections.
23
Benjamin Peterson41181742008-07-02 20:22:54 +000024.. seealso::
25
26 :pep:`324` -- PEP proposing the subprocess module
27
Georg Brandl116aa622007-08-15 14:28:22 +000028
Ezio Melotti402f75d2012-11-08 10:07:10 +020029Using the :mod:`subprocess` Module
30----------------------------------
Georg Brandl116aa622007-08-15 14:28:22 +000031
Gregory P. Smith6e730002015-04-14 16:14:25 -070032The recommended approach to invoking subprocesses is to use the :func:`run`
Benjamin Petersonef9ffcb2015-04-14 22:12:14 -040033function for all use cases it can handle. For more advanced use cases, the
34underlying :class:`Popen` interface can be used directly.
Nick Coghlanc29248f2011-11-08 20:49:23 +100035
Gregory P. Smith6e730002015-04-14 16:14:25 -070036The :func:`run` function was added in Python 3.5; if you need to retain
37compatibility with older versions, see the :ref:`call-function-trio` section.
Nick Coghlanc29248f2011-11-08 20:49:23 +100038
Gregory P. Smith6e730002015-04-14 16:14:25 -070039
40.. function:: run(args, *, stdin=None, input=None, stdout=None, stderr=None,\
Andriy Maletsky22d131a2018-08-09 23:01:54 +030041 capture_output=False, shell=False, cwd=None, timeout=None, \
Jakub Stasiak7432f092018-11-12 04:40:42 +010042 check=False, encoding=None, errors=None, text=None, env=None, \
43 universal_newlines=None)
Nick Coghlanc29248f2011-11-08 20:49:23 +100044
45 Run the command described by *args*. Wait for command to complete, then
Gregory P. Smith6e730002015-04-14 16:14:25 -070046 return a :class:`CompletedProcess` instance.
Nick Coghlanc29248f2011-11-08 20:49:23 +100047
48 The arguments shown above are merely the most common ones, described below
Nick Coghlan217f05b2011-11-08 22:11:21 +100049 in :ref:`frequently-used-arguments` (hence the use of keyword-only notation
50 in the abbreviated signature). The full function signature is largely the
Bo Baylesce0f33d2018-01-30 00:40:39 -060051 same as that of the :class:`Popen` constructor - most of the arguments to
52 this function are passed through to that interface. (*timeout*, *input*,
53 *check*, and *capture_output* are not.)
Nick Coghlan217f05b2011-11-08 22:11:21 +100054
Bo Baylesce0f33d2018-01-30 00:40:39 -060055 If *capture_output* is true, stdout and stderr will be captured.
56 When used, the internal :class:`Popen` object is automatically created with
57 ``stdout=PIPE`` and ``stderr=PIPE``. The *stdout* and *stderr* arguments may
Gregory P. Smithe8830912019-05-14 12:33:17 -070058 not be supplied at the same time as *capture_output*. If you wish to capture
59 and combine both streams into one, use ``stdout=PIPE`` and ``stderr=STDOUT``
60 instead of *capture_output*.
Nick Coghlanc29248f2011-11-08 20:49:23 +100061
Gregory P. Smith6e730002015-04-14 16:14:25 -070062 The *timeout* argument is passed to :meth:`Popen.communicate`. If the timeout
63 expires, the child process will be killed and waited for. The
Nick Coghlan217f05b2011-11-08 22:11:21 +100064 :exc:`TimeoutExpired` exception will be re-raised after the child process
65 has terminated.
Nick Coghlanc29248f2011-11-08 20:49:23 +100066
Serhiy Storchakafcd9f222013-04-22 20:20:54 +030067 The *input* argument is passed to :meth:`Popen.communicate` and thus to the
68 subprocess's stdin. If used it must be a byte sequence, or a string if
andyclegg7fed7bd2017-10-23 03:01:19 +010069 *encoding* or *errors* is specified or *text* is true. When
Steve Dower050acae2016-09-06 20:16:17 -070070 used, the internal :class:`Popen` object is automatically created with
71 ``stdin=PIPE``, and the *stdin* argument may not be used as well.
Serhiy Storchakafcd9f222013-04-22 20:20:54 +030072
Serhiy Storchaka4adf01c2016-10-19 18:30:05 +030073 If *check* is true, and the process exits with a non-zero exit code, a
Gregory P. Smith6e730002015-04-14 16:14:25 -070074 :exc:`CalledProcessError` exception will be raised. Attributes of that
75 exception hold the arguments, the exit code, and stdout and stderr if they
76 were captured.
77
andyclegg7fed7bd2017-10-23 03:01:19 +010078 If *encoding* or *errors* are specified, or *text* is true,
Steve Dower050acae2016-09-06 20:16:17 -070079 file objects for stdin, stdout and stderr are opened in text mode using the
80 specified *encoding* and *errors* or the :class:`io.TextIOWrapper` default.
andyclegg7fed7bd2017-10-23 03:01:19 +010081 The *universal_newlines* argument is equivalent to *text* and is provided
82 for backwards compatibility. By default, file objects are opened in binary mode.
Steve Dower050acae2016-09-06 20:16:17 -070083
Tobias Kunzeaf1ec972018-06-05 13:41:42 +020084 If *env* is not ``None``, it must be a mapping that defines the environment
85 variables for the new process; these are used instead of the default
86 behavior of inheriting the current process' environment. It is passed directly
87 to :class:`Popen`.
88
Nick Coghlanc29248f2011-11-08 20:49:23 +100089 Examples::
90
Gregory P. Smith6e730002015-04-14 16:14:25 -070091 >>> subprocess.run(["ls", "-l"]) # doesn't capture output
92 CompletedProcess(args=['ls', '-l'], returncode=0)
Nick Coghlanc29248f2011-11-08 20:49:23 +100093
Gregory P. Smith6e730002015-04-14 16:14:25 -070094 >>> subprocess.run("exit 1", shell=True, check=True)
Nick Coghlanc29248f2011-11-08 20:49:23 +100095 Traceback (most recent call last):
Gregory P. Smith6e730002015-04-14 16:14:25 -070096 ...
Nick Coghlanc29248f2011-11-08 20:49:23 +100097 subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1
98
Bo Baylesce0f33d2018-01-30 00:40:39 -060099 >>> subprocess.run(["ls", "-l", "/dev/null"], capture_output=True)
Gregory P. Smith6e730002015-04-14 16:14:25 -0700100 CompletedProcess(args=['ls', '-l', '/dev/null'], returncode=0,
Bo Baylesce0f33d2018-01-30 00:40:39 -0600101 stdout=b'crw-rw-rw- 1 root root 1, 3 Jan 23 16:23 /dev/null\n', stderr=b'')
Nick Coghlanc29248f2011-11-08 20:49:23 +1000102
Gregory P. Smith6e730002015-04-14 16:14:25 -0700103 .. versionadded:: 3.5
Nick Coghlanc29248f2011-11-08 20:49:23 +1000104
Steve Dower050acae2016-09-06 20:16:17 -0700105 .. versionchanged:: 3.6
106
107 Added *encoding* and *errors* parameters
108
andyclegg7fed7bd2017-10-23 03:01:19 +0100109 .. versionchanged:: 3.7
110
Bo Baylesce0f33d2018-01-30 00:40:39 -0600111 Added the *text* parameter, as a more understandable alias of *universal_newlines*.
112 Added the *capture_output* parameter.
andyclegg7fed7bd2017-10-23 03:01:19 +0100113
Gregory P. Smith6e730002015-04-14 16:14:25 -0700114.. class:: CompletedProcess
Nick Coghlanc29248f2011-11-08 20:49:23 +1000115
Gregory P. Smith6e730002015-04-14 16:14:25 -0700116 The return value from :func:`run`, representing a process that has finished.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000117
Gregory P. Smith6e730002015-04-14 16:14:25 -0700118 .. attribute:: args
Nick Coghlanc29248f2011-11-08 20:49:23 +1000119
Gregory P. Smith6e730002015-04-14 16:14:25 -0700120 The arguments used to launch the process. This may be a list or a string.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000121
Gregory P. Smith6e730002015-04-14 16:14:25 -0700122 .. attribute:: returncode
Serhiy Storchakafcd9f222013-04-22 20:20:54 +0300123
Gregory P. Smith6e730002015-04-14 16:14:25 -0700124 Exit status of the child process. Typically, an exit status of 0 indicates
125 that it ran successfully.
Nick Coghlan217f05b2011-11-08 22:11:21 +1000126
Gregory P. Smith6e730002015-04-14 16:14:25 -0700127 A negative value ``-N`` indicates that the child was terminated by signal
128 ``N`` (POSIX only).
129
130 .. attribute:: stdout
131
132 Captured stdout from the child process. A bytes sequence, or a string if
andyclegg7fed7bd2017-10-23 03:01:19 +0100133 :func:`run` was called with an encoding, errors, or text=True.
134 ``None`` if stdout was not captured.
Gregory P. Smith6e730002015-04-14 16:14:25 -0700135
136 If you ran the process with ``stderr=subprocess.STDOUT``, stdout and
137 stderr will be combined in this attribute, and :attr:`stderr` will be
Serhiy Storchakaecf41da2016-10-19 16:29:26 +0300138 ``None``.
Gregory P. Smith6e730002015-04-14 16:14:25 -0700139
140 .. attribute:: stderr
141
142 Captured stderr from the child process. A bytes sequence, or a string if
andyclegg7fed7bd2017-10-23 03:01:19 +0100143 :func:`run` was called with an encoding, errors, or text=True.
144 ``None`` if stderr was not captured.
Gregory P. Smith6e730002015-04-14 16:14:25 -0700145
146 .. method:: check_returncode()
147
148 If :attr:`returncode` is non-zero, raise a :exc:`CalledProcessError`.
149
150 .. versionadded:: 3.5
Nick Coghlan217f05b2011-11-08 22:11:21 +1000151
152.. data:: DEVNULL
153
154 Special value that can be used as the *stdin*, *stdout* or *stderr* argument
155 to :class:`Popen` and indicates that the special file :data:`os.devnull`
156 will be used.
157
158 .. versionadded:: 3.3
159
Nick Coghlanc29248f2011-11-08 20:49:23 +1000160
161.. data:: PIPE
162
163 Special value that can be used as the *stdin*, *stdout* or *stderr* argument
164 to :class:`Popen` and indicates that a pipe to the standard stream should be
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700165 opened. Most useful with :meth:`Popen.communicate`.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000166
167
168.. data:: STDOUT
169
170 Special value that can be used as the *stderr* argument to :class:`Popen` and
171 indicates that standard error should go into the same handle as standard
172 output.
173
174
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300175.. exception:: SubprocessError
176
177 Base class for all other exceptions from this module.
178
179 .. versionadded:: 3.3
180
181
182.. exception:: TimeoutExpired
183
184 Subclass of :exc:`SubprocessError`, raised when a timeout expires
185 while waiting for a child process.
186
187 .. attribute:: cmd
188
189 Command that was used to spawn the child process.
190
191 .. attribute:: timeout
192
193 Timeout in seconds.
194
195 .. attribute:: output
196
Gregory P. Smith6e730002015-04-14 16:14:25 -0700197 Output of the child process if it was captured by :func:`run` or
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300198 :func:`check_output`. Otherwise, ``None``.
199
Gregory P. Smith6e730002015-04-14 16:14:25 -0700200 .. attribute:: stdout
201
202 Alias for output, for symmetry with :attr:`stderr`.
203
204 .. attribute:: stderr
205
206 Stderr output of the child process if it was captured by :func:`run`.
207 Otherwise, ``None``.
208
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300209 .. versionadded:: 3.3
210
Gregory P. Smith6e730002015-04-14 16:14:25 -0700211 .. versionchanged:: 3.5
212 *stdout* and *stderr* attributes added
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300213
214.. exception:: CalledProcessError
215
216 Subclass of :exc:`SubprocessError`, raised when a process run by
217 :func:`check_call` or :func:`check_output` returns a non-zero exit status.
218
219 .. attribute:: returncode
220
Gregory P. Smith ext:(%20%5BGoogle%20Inc.%5D)583a1d62016-06-03 00:31:21 +0000221 Exit status of the child process. If the process exited due to a
222 signal, this will be the negative signal number.
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300223
224 .. attribute:: cmd
225
226 Command that was used to spawn the child process.
227
228 .. attribute:: output
229
Gregory P. Smith6e730002015-04-14 16:14:25 -0700230 Output of the child process if it was captured by :func:`run` or
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300231 :func:`check_output`. Otherwise, ``None``.
232
Gregory P. Smith6e730002015-04-14 16:14:25 -0700233 .. attribute:: stdout
234
235 Alias for output, for symmetry with :attr:`stderr`.
236
237 .. attribute:: stderr
238
239 Stderr output of the child process if it was captured by :func:`run`.
240 Otherwise, ``None``.
241
242 .. versionchanged:: 3.5
243 *stdout* and *stderr* attributes added
Andrew Svetlovb4a09ab2012-08-09 15:11:45 +0300244
245
Nick Coghlanc29248f2011-11-08 20:49:23 +1000246.. _frequently-used-arguments:
247
248Frequently Used Arguments
249^^^^^^^^^^^^^^^^^^^^^^^^^
250
251To support a wide variety of use cases, the :class:`Popen` constructor (and
252the convenience functions) accept a large number of optional arguments. For
253most typical use cases, many of these arguments can be safely left at their
254default values. The arguments that are most commonly needed are:
255
256 *args* is required for all calls and should be a string, or a sequence of
257 program arguments. Providing a sequence of arguments is generally
258 preferred, as it allows the module to take care of any required escaping
259 and quoting of arguments (e.g. to permit spaces in file names). If passing
260 a single string, either *shell* must be :const:`True` (see below) or else
261 the string must simply name the program to be executed without specifying
262 any arguments.
263
264 *stdin*, *stdout* and *stderr* specify the executed program's standard input,
265 standard output and standard error file handles, respectively. Valid values
Nick Coghlan217f05b2011-11-08 22:11:21 +1000266 are :data:`PIPE`, :data:`DEVNULL`, an existing file descriptor (a positive
267 integer), an existing file object, and ``None``. :data:`PIPE` indicates
268 that a new pipe to the child should be created. :data:`DEVNULL` indicates
269 that the special file :data:`os.devnull` will be used. With the default
270 settings of ``None``, no redirection will occur; the child's file handles
271 will be inherited from the parent. Additionally, *stderr* can be
272 :data:`STDOUT`, which indicates that the stderr data from the child
273 process should be captured into the same file handle as for *stdout*.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000274
R David Murray1b00f252012-08-15 10:43:58 -0400275 .. index::
276 single: universal newlines; subprocess module
277
Pablo Galindoe14c0102018-02-11 20:58:23 +0000278 If *encoding* or *errors* are specified, or *text* (also known as
279 *universal_newlines*) is true,
Steve Dower050acae2016-09-06 20:16:17 -0700280 the file objects *stdin*, *stdout* and *stderr* will be opened in text
281 mode using the *encoding* and *errors* specified in the call or the
282 defaults for :class:`io.TextIOWrapper`.
Ronald Oussoren385521c2013-07-07 09:26:45 +0200283
Steve Dower050acae2016-09-06 20:16:17 -0700284 For *stdin*, line ending characters ``'\n'`` in the input will be converted
285 to the default line separator :data:`os.linesep`. For *stdout* and *stderr*,
286 all line endings in the output will be converted to ``'\n'``. For more
287 information see the documentation of the :class:`io.TextIOWrapper` class
288 when the *newline* argument to its constructor is ``None``.
289
290 If text mode is not used, *stdin*, *stdout* and *stderr* will be opened as
291 binary streams. No encoding or line ending conversion is performed.
292
293 .. versionadded:: 3.6
294 Added *encoding* and *errors* parameters.
Nick Coghlanc29248f2011-11-08 20:49:23 +1000295
Pablo Galindoe14c0102018-02-11 20:58:23 +0000296 .. versionadded:: 3.7
297 Added the *text* parameter as an alias for *universal_newlines*.
298
Andrew Svetlov50be4522012-08-13 22:09:04 +0300299 .. note::
300
Gregory P. Smith1f8a40b2013-03-20 18:32:03 -0700301 The newlines attribute of the file objects :attr:`Popen.stdin`,
302 :attr:`Popen.stdout` and :attr:`Popen.stderr` are not updated by
303 the :meth:`Popen.communicate` method.
Andrew Svetlov50be4522012-08-13 22:09:04 +0300304
305 If *shell* is ``True``, the specified command will be executed through
Ezio Melotti186d5232012-09-15 08:34:08 +0300306 the shell. This can be useful if you are using Python primarily for the
Nick Coghlanc29248f2011-11-08 20:49:23 +1000307 enhanced control flow it offers over most system shells and still want
Ezio Melotti186d5232012-09-15 08:34:08 +0300308 convenient access to other shell features such as shell pipes, filename
309 wildcards, environment variable expansion, and expansion of ``~`` to a
310 user's home directory. However, note that Python itself offers
311 implementations of many shell-like features (in particular, :mod:`glob`,
312 :mod:`fnmatch`, :func:`os.walk`, :func:`os.path.expandvars`,
313 :func:`os.path.expanduser`, and :mod:`shutil`).
Nick Coghlanc29248f2011-11-08 20:49:23 +1000314
Andrew Svetlov4805fa82012-08-13 22:11:14 +0300315 .. versionchanged:: 3.3
316 When *universal_newlines* is ``True``, the class uses the encoding
317 :func:`locale.getpreferredencoding(False) <locale.getpreferredencoding>`
318 instead of ``locale.getpreferredencoding()``. See the
319 :class:`io.TextIOWrapper` class for more information on this change.
320
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700321 .. note::
Nick Coghlanc29248f2011-11-08 20:49:23 +1000322
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700323 Read the `Security Considerations`_ section before using ``shell=True``.
Andrew Svetlovc2415eb2012-10-28 11:42:26 +0200324
Nick Coghlanc29248f2011-11-08 20:49:23 +1000325These options, along with all of the other options, are described in more
326detail in the :class:`Popen` constructor documentation.
327
328
Sandro Tosi1526ad12011-12-25 11:27:37 +0100329Popen Constructor
Sandro Tosi3e6c8142011-12-25 17:14:11 +0100330^^^^^^^^^^^^^^^^^
Nick Coghlanc29248f2011-11-08 20:49:23 +1000331
332The underlying process creation and management in this module is handled by
333the :class:`Popen` class. It offers a lot of flexibility so that developers
334are able to handle the less common cases not covered by the convenience
335functions.
Georg Brandl116aa622007-08-15 14:28:22 +0000336
337
Gregory P. Smitha1ed5392013-03-23 11:44:25 -0700338.. class:: Popen(args, bufsize=-1, executable=None, stdin=None, stdout=None, \
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700339 stderr=None, preexec_fn=None, close_fds=True, shell=False, \
Jakub Stasiak7432f092018-11-12 04:40:42 +0100340 cwd=None, env=None, universal_newlines=None, \
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700341 startupinfo=None, creationflags=0, restore_signals=True, \
Steve Dower050acae2016-09-06 20:16:17 -0700342 start_new_session=False, pass_fds=(), *, \
Pablo Galindoe14c0102018-02-11 20:58:23 +0000343 encoding=None, errors=None, text=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000344
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700345 Execute a child program in a new process. On POSIX, the class uses
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700346 :meth:`os.execvp`-like behavior to execute the child program. On Windows,
347 the class uses the Windows ``CreateProcess()`` function. The arguments to
348 :class:`Popen` are as follows.
Georg Brandl116aa622007-08-15 14:28:22 +0000349
Serhiy Storchaka9e3c4522019-05-28 22:49:35 +0300350 *args* should be a sequence of program arguments or else a single string
351 or :term:`path-like object`.
Serhiy Storchakabe50a7b2018-02-28 01:03:46 +0200352 By default, the program to execute is the first item in *args* if *args* is
353 a sequence. If *args* is a string, the interpretation is
354 platform-dependent and described below. See the *shell* and *executable*
355 arguments for additional differences from the default behavior. Unless
356 otherwise stated, it is recommended to pass *args* as a sequence.
Georg Brandl116aa622007-08-15 14:28:22 +0000357
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700358 On POSIX, if *args* is a string, the string is interpreted as the name or
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700359 path of the program to execute. However, this can only be done if not
360 passing arguments to the program.
Georg Brandl116aa622007-08-15 14:28:22 +0000361
R. David Murray5973e4d2010-02-04 16:41:57 +0000362 .. note::
363
364 :meth:`shlex.split` can be useful when determining the correct
365 tokenization for *args*, especially in complex cases::
366
367 >>> import shlex, subprocess
R. David Murray73bc75b2010-02-05 16:25:12 +0000368 >>> command_line = input()
R. David Murray5973e4d2010-02-04 16:41:57 +0000369 /bin/vikings -input eggs.txt -output "spam spam.txt" -cmd "echo '$MONEY'"
370 >>> args = shlex.split(command_line)
371 >>> print(args)
372 ['/bin/vikings', '-input', 'eggs.txt', '-output', 'spam spam.txt', '-cmd', "echo '$MONEY'"]
373 >>> p = subprocess.Popen(args) # Success!
374
375 Note in particular that options (such as *-input*) and arguments (such
376 as *eggs.txt*) that are separated by whitespace in the shell go in separate
377 list elements, while arguments that need quoting or backslash escaping when
378 used in the shell (such as filenames containing spaces or the *echo* command
379 shown above) are single list elements.
380
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700381 On Windows, if *args* is a sequence, it will be converted to a string in a
382 manner described in :ref:`converting-argument-sequence`. This is because
383 the underlying ``CreateProcess()`` operates on strings.
Chris Jerdonek470ee392012-10-08 23:06:57 -0700384
Serhiy Storchaka9e3c4522019-05-28 22:49:35 +0300385 .. versionchanged:: 3.6
386 *args* parameter accepts a :term:`path-like object` if *shell* is
387 ``False`` and a sequence containing path-like objects on POSIX.
388
389 .. versionchanged:: 3.8
390 *args* parameter accepts a :term:`path-like object` if *shell* is
391 ``False`` and a sequence containing bytes and path-like objects
392 on Windows.
393
Serhiy Storchakaa97cd2e2016-10-19 16:43:42 +0300394 The *shell* argument (which defaults to ``False``) specifies whether to use
395 the shell as the program to execute. If *shell* is ``True``, it is
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700396 recommended to pass *args* as a string rather than as a sequence.
Chris Jerdonek470ee392012-10-08 23:06:57 -0700397
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700398 On POSIX with ``shell=True``, the shell defaults to :file:`/bin/sh`. If
Chris Jerdonek470ee392012-10-08 23:06:57 -0700399 *args* is a string, the string specifies the command
400 to execute through the shell. This means that the string must be
R. David Murray5973e4d2010-02-04 16:41:57 +0000401 formatted exactly as it would be when typed at the shell prompt. This
402 includes, for example, quoting or backslash escaping filenames with spaces in
403 them. If *args* is a sequence, the first item specifies the command string, and
404 any additional items will be treated as additional arguments to the shell
Chris Jerdonek470ee392012-10-08 23:06:57 -0700405 itself. That is to say, :class:`Popen` does the equivalent of::
R. David Murray5973e4d2010-02-04 16:41:57 +0000406
407 Popen(['/bin/sh', '-c', args[0], args[1], ...])
Georg Brandl116aa622007-08-15 14:28:22 +0000408
Chris Jerdonek470ee392012-10-08 23:06:57 -0700409 On Windows with ``shell=True``, the :envvar:`COMSPEC` environment variable
410 specifies the default shell. The only time you need to specify
411 ``shell=True`` on Windows is when the command you wish to execute is built
412 into the shell (e.g. :command:`dir` or :command:`copy`). You do not need
413 ``shell=True`` to run a batch file or console-based executable.
Georg Brandl116aa622007-08-15 14:28:22 +0000414
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700415 .. note::
Chris Jerdonekcc32a682012-10-10 22:52:22 -0700416
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700417 Read the `Security Considerations`_ section before using ``shell=True``.
Chris Jerdonekcc32a682012-10-10 22:52:22 -0700418
Antoine Pitrouafe8d062014-09-21 21:10:56 +0200419 *bufsize* will be supplied as the corresponding argument to the
420 :func:`open` function when creating the stdin/stdout/stderr pipe
421 file objects:
422
423 - :const:`0` means unbuffered (read and write are one
424 system call and can return short)
425 - :const:`1` means line buffered
426 (only usable if ``universal_newlines=True`` i.e., in a text mode)
427 - any other positive value means use a buffer of approximately that
428 size
429 - negative bufsize (the default) means the system default of
430 io.DEFAULT_BUFFER_SIZE will be used.
Georg Brandl116aa622007-08-15 14:28:22 +0000431
Georg Brandl37b70bb2013-11-25 08:48:37 +0100432 .. versionchanged:: 3.3.1
Gregory P. Smitha1ed5392013-03-23 11:44:25 -0700433 *bufsize* now defaults to -1 to enable buffering by default to match the
Georg Brandl37b70bb2013-11-25 08:48:37 +0100434 behavior that most code expects. In versions prior to Python 3.2.4 and
435 3.3.1 it incorrectly defaulted to :const:`0` which was unbuffered
436 and allowed short reads. This was unintentional and did not match the
437 behavior of Python 2 as most code expected.
Antoine Pitrou4b876202010-06-02 17:10:49 +0000438
Chris Jerdonek470ee392012-10-08 23:06:57 -0700439 The *executable* argument specifies a replacement program to execute. It
440 is very seldom needed. When ``shell=False``, *executable* replaces the
Chris Jerdonek4a4a02b2012-10-10 17:46:18 -0700441 program to execute specified by *args*. However, the original *args* is
442 still passed to the program. Most programs treat the program specified
443 by *args* as the command name, which can then be different from the program
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700444 actually executed. On POSIX, the *args* name
Chris Jerdonek470ee392012-10-08 23:06:57 -0700445 becomes the display name for the executable in utilities such as
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700446 :program:`ps`. If ``shell=True``, on POSIX the *executable* argument
Chris Jerdonek470ee392012-10-08 23:06:57 -0700447 specifies a replacement shell for the default :file:`/bin/sh`.
Georg Brandl116aa622007-08-15 14:28:22 +0000448
Serhiy Storchaka9e3c4522019-05-28 22:49:35 +0300449 .. versionchanged:: 3.6
450 *executable* parameter accepts a :term:`path-like object` on POSIX.
451
452 .. versionchanged:: 3.8
453 *executable* parameter accepts a bytes and :term:`path-like object`
454 on Windows.
455
Nick Coghlanc29248f2011-11-08 20:49:23 +1000456 *stdin*, *stdout* and *stderr* specify the executed program's standard input,
Georg Brandlaf265f42008-12-07 15:06:20 +0000457 standard output and standard error file handles, respectively. Valid values
Ross Lagerwallba102ec2011-03-16 18:40:25 +0200458 are :data:`PIPE`, :data:`DEVNULL`, an existing file descriptor (a positive
459 integer), an existing :term:`file object`, and ``None``. :data:`PIPE`
460 indicates that a new pipe to the child should be created. :data:`DEVNULL`
Nick Coghlan217f05b2011-11-08 22:11:21 +1000461 indicates that the special file :data:`os.devnull` will be used. With the
462 default settings of ``None``, no redirection will occur; the child's file
463 handles will be inherited from the parent. Additionally, *stderr* can be
464 :data:`STDOUT`, which indicates that the stderr data from the applications
465 should be captured into the same file handle as for stdout.
Georg Brandl116aa622007-08-15 14:28:22 +0000466
467 If *preexec_fn* is set to a callable object, this object will be called in the
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000468 child process just before the child is executed.
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700469 (POSIX only)
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000470
471 .. warning::
472
473 The *preexec_fn* parameter is not safe to use in the presence of threads
474 in your application. The child process could deadlock before exec is
475 called.
476 If you must use it, keep it trivial! Minimize the number of libraries
477 you call into.
478
479 .. note::
480
481 If you need to modify the environment for the child use the *env*
482 parameter rather than doing it in a *preexec_fn*.
483 The *start_new_session* parameter can take the place of a previously
484 common use of *preexec_fn* to call os.setsid() in the child.
Georg Brandl116aa622007-08-15 14:28:22 +0000485
486 If *close_fds* is true, all file descriptors except :const:`0`, :const:`1` and
Gregory P. Smithdfb6e542018-03-25 10:27:59 -0700487 :const:`2` will be closed before the child process is executed. Otherwise
488 when *close_fds* is false, file descriptors obey their inheritable flag
489 as described in :ref:`fd_inheritance`.
490
Gregory P. Smithd23047b2010-12-04 09:10:44 +0000491 On Windows, if *close_fds* is true then no handles will be inherited by the
Segev Finerb2a60832017-12-18 11:28:19 +0200492 child process unless explicitly passed in the ``handle_list`` element of
493 :attr:`STARTUPINFO.lpAttributeList`, or by standard handle redirection.
Georg Brandl116aa622007-08-15 14:28:22 +0000494
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000495 .. versionchanged:: 3.2
496 The default for *close_fds* was changed from :const:`False` to
497 what is described above.
498
Segev Finerb2a60832017-12-18 11:28:19 +0200499 .. versionchanged:: 3.7
500 On Windows the default for *close_fds* was changed from :const:`False` to
501 :const:`True` when redirecting the standard handles. It's now possible to
502 set *close_fds* to :const:`True` when redirecting the standard handles.
503
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000504 *pass_fds* is an optional sequence of file descriptors to keep open
505 between the parent and child. Providing any *pass_fds* forces
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700506 *close_fds* to be :const:`True`. (POSIX only)
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000507
Sergey Fedoseevf1202882018-07-06 05:01:16 +0500508 .. versionchanged:: 3.2
Gregory P. Smith8edd99d2010-12-14 13:43:30 +0000509 The *pass_fds* parameter was added.
Georg Brandl116aa622007-08-15 14:28:22 +0000510
Chris Jerdonekec3ea942012-09-30 00:10:28 -0700511 If *cwd* is not ``None``, the function changes the working directory to
Serhiy Storchaka9e3c4522019-05-28 22:49:35 +0300512 *cwd* before executing the child. *cwd* can be a string, bytes or
Sayan Chowdhuryd5c11f72017-02-26 22:36:10 +0530513 :term:`path-like <path-like object>` object. In particular, the function
514 looks for *executable* (or for the first item in *args*) relative to *cwd*
515 if the executable path is a relative path.
516
517 .. versionchanged:: 3.6
Serhiy Storchaka9e3c4522019-05-28 22:49:35 +0300518 *cwd* parameter accepts a :term:`path-like object` on POSIX.
519
520 .. versionchanged:: 3.7
521 *cwd* parameter accepts a :term:`path-like object` on Windows.
522
523 .. versionchanged:: 3.8
524 *cwd* parameter accepts a bytes object on Windows.
Georg Brandl116aa622007-08-15 14:28:22 +0000525
Serhiy Storchakafbc1c262013-11-29 12:17:13 +0200526 If *restore_signals* is true (the default) all signals that Python has set to
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000527 SIG_IGN are restored to SIG_DFL in the child process before the exec.
528 Currently this includes the SIGPIPE, SIGXFZ and SIGXFSZ signals.
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700529 (POSIX only)
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000530
531 .. versionchanged:: 3.2
532 *restore_signals* was added.
533
Serhiy Storchakafbc1c262013-11-29 12:17:13 +0200534 If *start_new_session* is true the setsid() system call will be made in the
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700535 child process prior to the execution of the subprocess. (POSIX only)
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000536
537 .. versionchanged:: 3.2
538 *start_new_session* was added.
539
Christian Heimesa342c012008-04-20 21:01:16 +0000540 If *env* is not ``None``, it must be a mapping that defines the environment
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000541 variables for the new process; these are used instead of the default
542 behavior of inheriting the current process' environment.
Georg Brandl116aa622007-08-15 14:28:22 +0000543
R. David Murray1055e892009-04-16 18:15:32 +0000544 .. note::
R. David Murrayf4ac1492009-04-15 22:35:15 +0000545
Georg Brandl2708f3a2009-12-20 14:38:23 +0000546 If specified, *env* must provide any variables required for the program to
547 execute. On Windows, in order to run a `side-by-side assembly`_ the
548 specified *env* **must** include a valid :envvar:`SystemRoot`.
R. David Murrayf4ac1492009-04-15 22:35:15 +0000549
Georg Brandl5d941342016-02-26 19:37:12 +0100550 .. _side-by-side assembly: https://en.wikipedia.org/wiki/Side-by-Side_Assembly
R. David Murray1055e892009-04-16 18:15:32 +0000551
Pablo Galindoe14c0102018-02-11 20:58:23 +0000552 If *encoding* or *errors* are specified, or *text* is true, the file objects
553 *stdin*, *stdout* and *stderr* are opened in text mode with the specified
554 encoding and *errors*, as described above in :ref:`frequently-used-arguments`.
555 The *universal_newlines* argument is equivalent to *text* and is provided
556 for backwards compatibility. By default, file objects are opened in binary mode.
Steve Dower050acae2016-09-06 20:16:17 -0700557
558 .. versionadded:: 3.6
559 *encoding* and *errors* were added.
Georg Brandl116aa622007-08-15 14:28:22 +0000560
Pablo Galindoe14c0102018-02-11 20:58:23 +0000561 .. versionadded:: 3.7
562 *text* was added as a more readable alias for *universal_newlines*.
563
Brian Curtine6242d72011-04-29 22:17:51 -0500564 If given, *startupinfo* will be a :class:`STARTUPINFO` object, which is
565 passed to the underlying ``CreateProcess`` function.
Jamesb5d9e082017-11-08 14:18:59 +0000566 *creationflags*, if given, can be one or more of the following flags:
567
568 * :data:`CREATE_NEW_CONSOLE`
569 * :data:`CREATE_NEW_PROCESS_GROUP`
570 * :data:`ABOVE_NORMAL_PRIORITY_CLASS`
571 * :data:`BELOW_NORMAL_PRIORITY_CLASS`
572 * :data:`HIGH_PRIORITY_CLASS`
573 * :data:`IDLE_PRIORITY_CLASS`
574 * :data:`NORMAL_PRIORITY_CLASS`
575 * :data:`REALTIME_PRIORITY_CLASS`
576 * :data:`CREATE_NO_WINDOW`
577 * :data:`DETACHED_PROCESS`
578 * :data:`CREATE_DEFAULT_ERROR_MODE`
579 * :data:`CREATE_BREAKAWAY_FROM_JOB`
Georg Brandl116aa622007-08-15 14:28:22 +0000580
Gregory P. Smith6b657452011-05-11 21:42:08 -0700581 Popen objects are supported as context managers via the :keyword:`with` statement:
582 on exit, standard file descriptors are closed, and the process is waited for.
Brian Curtin79cdb662010-12-03 02:46:02 +0000583 ::
584
585 with Popen(["ifconfig"], stdout=PIPE) as proc:
586 log.write(proc.stdout.read())
587
Steve Dower60419a72019-06-24 08:42:54 -0700588 .. audit-event:: subprocess.Popen "executable args cwd env"
589
590 Popen and the other functions in this module that use it raise an
591 :ref:`auditing event <auditing>` ``subprocess.Popen`` with arguments
592 ``executable``, ``args``, ``cwd``, ``env``. The value for ``args``
593 may be a single string or a list of strings, depending on platform.
594
Brian Curtin79cdb662010-12-03 02:46:02 +0000595 .. versionchanged:: 3.2
596 Added context manager support.
597
Victor Stinner5a48e212016-05-20 12:11:15 +0200598 .. versionchanged:: 3.6
599 Popen destructor now emits a :exc:`ResourceWarning` warning if the child
600 process is still running.
601
Victor Stinnerd7befad2019-04-25 14:30:16 +0200602 .. versionchanged:: 3.8
603 Popen can use :func:`os.posix_spawn` in some cases for better
604 performance. On Windows Subsystem for Linux and QEMU User Emulation,
605 Popen constructor using :func:`os.posix_spawn` no longer raise an
606 exception on errors like missing program, but the child process fails
607 with a non-zero :attr:`~Popen.returncode`.
608
Georg Brandl116aa622007-08-15 14:28:22 +0000609
Georg Brandl116aa622007-08-15 14:28:22 +0000610Exceptions
611^^^^^^^^^^
612
613Exceptions raised in the child process, before the new program has started to
Harmandeep Singh47a2fce2019-01-04 01:23:56 +0530614execute, will be re-raised in the parent.
Georg Brandl116aa622007-08-15 14:28:22 +0000615
616The most common exception raised is :exc:`OSError`. This occurs, for example,
617when trying to execute a non-existent file. Applications should prepare for
618:exc:`OSError` exceptions.
619
620A :exc:`ValueError` will be raised if :class:`Popen` is called with invalid
621arguments.
622
Nick Coghlanc29248f2011-11-08 20:49:23 +1000623:func:`check_call` and :func:`check_output` will raise
624:exc:`CalledProcessError` if the called process returns a non-zero return
625code.
Georg Brandl116aa622007-08-15 14:28:22 +0000626
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400627All of the functions and methods that accept a *timeout* parameter, such as
628:func:`call` and :meth:`Popen.communicate` will raise :exc:`TimeoutExpired` if
629the timeout expires before the process exits.
630
Ronald Oussorenc1577902011-03-16 10:03:10 -0400631Exceptions defined in this module all inherit from :exc:`SubprocessError`.
Gregory P. Smith54d412e2011-03-14 14:08:43 -0400632
633 .. versionadded:: 3.3
634 The :exc:`SubprocessError` base class was added.
635
Georg Brandl116aa622007-08-15 14:28:22 +0000636
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700637Security Considerations
638-----------------------
Georg Brandl116aa622007-08-15 14:28:22 +0000639
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700640Unlike some other popen functions, this implementation will never
641implicitly call a system shell. This means that all characters,
642including shell metacharacters, can safely be passed to child processes.
643If the shell is invoked explicitly, via ``shell=True``, it is the application's
644responsibility to ensure that all whitespace and metacharacters are
645quoted appropriately to avoid
Georg Brandl5d941342016-02-26 19:37:12 +0100646`shell injection <https://en.wikipedia.org/wiki/Shell_injection#Shell_injection>`_
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700647vulnerabilities.
648
649When using ``shell=True``, the :func:`shlex.quote` function can be
650used to properly escape whitespace and shell metacharacters in strings
651that are going to be used to construct shell commands.
Georg Brandl116aa622007-08-15 14:28:22 +0000652
653
654Popen Objects
655-------------
656
657Instances of the :class:`Popen` class have the following methods:
658
659
660.. method:: Popen.poll()
661
Serhiy Storchaka9e0ae532013-08-24 00:23:38 +0300662 Check if child process has terminated. Set and return
Ivan Chernoff006617f2017-08-29 17:46:24 +0300663 :attr:`~Popen.returncode` attribute. Otherwise, returns ``None``.
Georg Brandl116aa622007-08-15 14:28:22 +0000664
665
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400666.. method:: Popen.wait(timeout=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000667
Serhiy Storchaka9e0ae532013-08-24 00:23:38 +0300668 Wait for child process to terminate. Set and return
669 :attr:`~Popen.returncode` attribute.
Georg Brandl116aa622007-08-15 14:28:22 +0000670
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400671 If the process does not terminate after *timeout* seconds, raise a
672 :exc:`TimeoutExpired` exception. It is safe to catch this exception and
673 retry the wait.
674
Victor Stinner07171242014-02-24 13:18:47 +0100675 .. note::
676
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700677 This will deadlock when using ``stdout=PIPE`` or ``stderr=PIPE``
678 and the child process generates enough output to a pipe such that
679 it blocks waiting for the OS pipe buffer to accept more data.
680 Use :meth:`Popen.communicate` when using pipes to avoid that.
681
682 .. note::
683
Victor Stinner07171242014-02-24 13:18:47 +0100684 The function is implemented using a busy loop (non-blocking call and
685 short sleeps). Use the :mod:`asyncio` module for an asynchronous wait:
686 see :class:`asyncio.create_subprocess_exec`.
687
Reid Kleckner28f13032011-03-14 12:36:53 -0400688 .. versionchanged:: 3.3
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400689 *timeout* was added.
Georg Brandl116aa622007-08-15 14:28:22 +0000690
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400691.. method:: Popen.communicate(input=None, timeout=None)
Georg Brandl116aa622007-08-15 14:28:22 +0000692
693 Interact with process: Send data to stdin. Read data from stdout and stderr,
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400694 until end-of-file is reached. Wait for process to terminate. The optional
Gregory P. Smitha454ef62011-05-22 22:29:49 -0700695 *input* argument should be data to be sent to the child process, or
Steve Dower050acae2016-09-06 20:16:17 -0700696 ``None``, if no data should be sent to the child. If streams were opened in
697 text mode, *input* must be a string. Otherwise, it must be bytes.
Georg Brandl116aa622007-08-15 14:28:22 +0000698
Victor Stinner39892052014-10-14 00:52:07 +0200699 :meth:`communicate` returns a tuple ``(stdout_data, stderr_data)``.
Steve Dower050acae2016-09-06 20:16:17 -0700700 The data will be strings if streams were opened in text mode; otherwise,
701 bytes.
Georg Brandl116aa622007-08-15 14:28:22 +0000702
Guido van Rossum0d3fb8a2007-11-26 23:23:18 +0000703 Note that if you want to send data to the process's stdin, you need to create
704 the Popen object with ``stdin=PIPE``. Similarly, to get anything other than
705 ``None`` in the result tuple, you need to give ``stdout=PIPE`` and/or
706 ``stderr=PIPE`` too.
707
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400708 If the process does not terminate after *timeout* seconds, a
709 :exc:`TimeoutExpired` exception will be raised. Catching this exception and
710 retrying communication will not lose any output.
711
712 The child process is not killed if the timeout expires, so in order to
713 cleanup properly a well-behaved application should kill the child process and
714 finish communication::
715
716 proc = subprocess.Popen(...)
717 try:
718 outs, errs = proc.communicate(timeout=15)
719 except TimeoutExpired:
720 proc.kill()
721 outs, errs = proc.communicate()
722
Christian Heimes7f044312008-01-06 17:05:40 +0000723 .. note::
Georg Brandl116aa622007-08-15 14:28:22 +0000724
Christian Heimes7f044312008-01-06 17:05:40 +0000725 The data read is buffered in memory, so do not use this method if the data
726 size is large or unlimited.
727
Reid Kleckner28f13032011-03-14 12:36:53 -0400728 .. versionchanged:: 3.3
Reid Kleckner31aa7dd2011-03-14 12:02:10 -0400729 *timeout* was added.
730
Georg Brandl116aa622007-08-15 14:28:22 +0000731
Christian Heimesa342c012008-04-20 21:01:16 +0000732.. method:: Popen.send_signal(signal)
733
734 Sends the signal *signal* to the child.
735
736 .. note::
737
Brian Curtineb24d742010-04-12 17:16:38 +0000738 On Windows, SIGTERM is an alias for :meth:`terminate`. CTRL_C_EVENT and
Senthil Kumaran916bd382010-10-15 12:55:19 +0000739 CTRL_BREAK_EVENT can be sent to processes started with a *creationflags*
Brian Curtineb24d742010-04-12 17:16:38 +0000740 parameter which includes `CREATE_NEW_PROCESS_GROUP`.
Christian Heimesa342c012008-04-20 21:01:16 +0000741
Christian Heimesa342c012008-04-20 21:01:16 +0000742
743.. method:: Popen.terminate()
744
745 Stop the child. On Posix OSs the method sends SIGTERM to the
Georg Brandl60203b42010-10-06 10:11:56 +0000746 child. On Windows the Win32 API function :c:func:`TerminateProcess` is called
Christian Heimesa342c012008-04-20 21:01:16 +0000747 to stop the child.
748
Christian Heimesa342c012008-04-20 21:01:16 +0000749
750.. method:: Popen.kill()
751
752 Kills the child. On Posix OSs the function sends SIGKILL to the child.
753 On Windows :meth:`kill` is an alias for :meth:`terminate`.
754
Christian Heimesa342c012008-04-20 21:01:16 +0000755
Georg Brandl116aa622007-08-15 14:28:22 +0000756The following attributes are also available:
757
Gregory P. Smith024c5ee2014-04-29 11:33:23 -0700758.. attribute:: Popen.args
759
760 The *args* argument as it was passed to :class:`Popen` -- a
761 sequence of program arguments or else a single string.
762
763 .. versionadded:: 3.3
Georg Brandl734e2682008-08-12 08:18:18 +0000764
Georg Brandl116aa622007-08-15 14:28:22 +0000765.. attribute:: Popen.stdin
766
Benjamin Peterson3d8814e2014-01-18 00:45:56 -0500767 If the *stdin* argument was :data:`PIPE`, this attribute is a writeable
Steve Dower050acae2016-09-06 20:16:17 -0700768 stream object as returned by :func:`open`. If the *encoding* or *errors*
769 arguments were specified or the *universal_newlines* argument was ``True``,
770 the stream is a text stream, otherwise it is a byte stream. If the *stdin*
771 argument was not :data:`PIPE`, this attribute is ``None``.
Georg Brandl116aa622007-08-15 14:28:22 +0000772
773
774.. attribute:: Popen.stdout
775
Benjamin Peterson3d8814e2014-01-18 00:45:56 -0500776 If the *stdout* argument was :data:`PIPE`, this attribute is a readable
777 stream object as returned by :func:`open`. Reading from the stream provides
Steve Dower050acae2016-09-06 20:16:17 -0700778 output from the child process. If the *encoding* or *errors* arguments were
779 specified or the *universal_newlines* argument was ``True``, the stream is a
780 text stream, otherwise it is a byte stream. If the *stdout* argument was not
781 :data:`PIPE`, this attribute is ``None``.
Benjamin Petersonaf69fe22014-01-18 00:49:04 -0500782
Georg Brandl116aa622007-08-15 14:28:22 +0000783
784.. attribute:: Popen.stderr
785
Benjamin Peterson3d8814e2014-01-18 00:45:56 -0500786 If the *stderr* argument was :data:`PIPE`, this attribute is a readable
787 stream object as returned by :func:`open`. Reading from the stream provides
Steve Dower050acae2016-09-06 20:16:17 -0700788 error output from the child process. If the *encoding* or *errors* arguments
789 were specified or the *universal_newlines* argument was ``True``, the stream
790 is a text stream, otherwise it is a byte stream. If the *stderr* argument was
791 not :data:`PIPE`, this attribute is ``None``.
Georg Brandl116aa622007-08-15 14:28:22 +0000792
Gregory P. Smith6436cba2014-05-11 13:26:21 -0700793.. warning::
794
795 Use :meth:`~Popen.communicate` rather than :attr:`.stdin.write <Popen.stdin>`,
796 :attr:`.stdout.read <Popen.stdout>` or :attr:`.stderr.read <Popen.stderr>` to avoid
797 deadlocks due to any of the other OS pipe buffers filling up and blocking the
798 child process.
799
Georg Brandl116aa622007-08-15 14:28:22 +0000800
801.. attribute:: Popen.pid
802
803 The process ID of the child process.
804
Georg Brandl58bfdca2010-03-21 09:50:49 +0000805 Note that if you set the *shell* argument to ``True``, this is the process ID
806 of the spawned shell.
807
Georg Brandl116aa622007-08-15 14:28:22 +0000808
809.. attribute:: Popen.returncode
810
Christian Heimes7f044312008-01-06 17:05:40 +0000811 The child return code, set by :meth:`poll` and :meth:`wait` (and indirectly
812 by :meth:`communicate`). A ``None`` value indicates that the process
813 hasn't terminated yet.
Georg Brandl48310cd2009-01-03 21:18:54 +0000814
Christian Heimes7f044312008-01-06 17:05:40 +0000815 A negative value ``-N`` indicates that the child was terminated by signal
Gregory P. Smith8e0aa052014-05-11 13:28:35 -0700816 ``N`` (POSIX only).
Georg Brandl116aa622007-08-15 14:28:22 +0000817
818
Brian Curtine6242d72011-04-29 22:17:51 -0500819Windows Popen Helpers
820---------------------
821
822The :class:`STARTUPINFO` class and following constants are only available
823on Windows.
824
Berker Peksagf5184742017-03-01 12:51:55 +0300825.. class:: STARTUPINFO(*, dwFlags=0, hStdInput=None, hStdOutput=None, \
Segev Finerb2a60832017-12-18 11:28:19 +0200826 hStdError=None, wShowWindow=0, lpAttributeList=None)
Brian Curtin73365dd2011-04-29 22:18:33 -0500827
Brian Curtine6242d72011-04-29 22:17:51 -0500828 Partial support of the Windows
Georg Brandl5d941342016-02-26 19:37:12 +0100829 `STARTUPINFO <https://msdn.microsoft.com/en-us/library/ms686331(v=vs.85).aspx>`__
Berker Peksagf5184742017-03-01 12:51:55 +0300830 structure is used for :class:`Popen` creation. The following attributes can
831 be set by passing them as keyword-only arguments.
832
833 .. versionchanged:: 3.7
834 Keyword-only argument support was added.
Brian Curtine6242d72011-04-29 22:17:51 -0500835
836 .. attribute:: dwFlags
837
Senthil Kumarana6bac952011-07-04 11:28:30 -0700838 A bit field that determines whether certain :class:`STARTUPINFO`
839 attributes are used when the process creates a window. ::
Brian Curtine6242d72011-04-29 22:17:51 -0500840
841 si = subprocess.STARTUPINFO()
842 si.dwFlags = subprocess.STARTF_USESTDHANDLES | subprocess.STARTF_USESHOWWINDOW
843
844 .. attribute:: hStdInput
845
Senthil Kumarana6bac952011-07-04 11:28:30 -0700846 If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
847 is the standard input handle for the process. If
848 :data:`STARTF_USESTDHANDLES` is not specified, the default for standard
849 input is the keyboard buffer.
Brian Curtine6242d72011-04-29 22:17:51 -0500850
851 .. attribute:: hStdOutput
852
Senthil Kumarana6bac952011-07-04 11:28:30 -0700853 If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
854 is the standard output handle for the process. Otherwise, this attribute
855 is ignored and the default for standard output is the console window's
Brian Curtine6242d72011-04-29 22:17:51 -0500856 buffer.
857
858 .. attribute:: hStdError
859
Senthil Kumarana6bac952011-07-04 11:28:30 -0700860 If :attr:`dwFlags` specifies :data:`STARTF_USESTDHANDLES`, this attribute
861 is the standard error handle for the process. Otherwise, this attribute is
Brian Curtine6242d72011-04-29 22:17:51 -0500862 ignored and the default for standard error is the console window's buffer.
863
864 .. attribute:: wShowWindow
865
Senthil Kumarana6bac952011-07-04 11:28:30 -0700866 If :attr:`dwFlags` specifies :data:`STARTF_USESHOWWINDOW`, this attribute
Brian Curtine6242d72011-04-29 22:17:51 -0500867 can be any of the values that can be specified in the ``nCmdShow``
868 parameter for the
Georg Brandl5d941342016-02-26 19:37:12 +0100869 `ShowWindow <https://msdn.microsoft.com/en-us/library/ms633548(v=vs.85).aspx>`__
Senthil Kumarana6bac952011-07-04 11:28:30 -0700870 function, except for ``SW_SHOWDEFAULT``. Otherwise, this attribute is
Brian Curtine6242d72011-04-29 22:17:51 -0500871 ignored.
Brian Curtin73365dd2011-04-29 22:18:33 -0500872
Brian Curtine6242d72011-04-29 22:17:51 -0500873 :data:`SW_HIDE` is provided for this attribute. It is used when
874 :class:`Popen` is called with ``shell=True``.
875
Segev Finerb2a60832017-12-18 11:28:19 +0200876 .. attribute:: lpAttributeList
877
878 A dictionary of additional attributes for process creation as given in
879 ``STARTUPINFOEX``, see
880 `UpdateProcThreadAttribute <https://msdn.microsoft.com/en-us/library/windows/desktop/ms686880(v=vs.85).aspx>`__.
881
882 Supported attributes:
883
884 **handle_list**
885 Sequence of handles that will be inherited. *close_fds* must be true if
886 non-empty.
887
888 The handles must be temporarily made inheritable by
889 :func:`os.set_handle_inheritable` when passed to the :class:`Popen`
890 constructor, else :class:`OSError` will be raised with Windows error
891 ``ERROR_INVALID_PARAMETER`` (87).
892
893 .. warning::
894
895 In a multithreaded process, use caution to avoid leaking handles
896 that are marked inheritable when combining this feature with
897 concurrent calls to other process creation functions that inherit
898 all handles such as :func:`os.system`. This also applies to
899 standard handle redirection, which temporarily creates inheritable
900 handles.
901
902 .. versionadded:: 3.7
Brian Curtine6242d72011-04-29 22:17:51 -0500903
Jamesb5d9e082017-11-08 14:18:59 +0000904Windows Constants
905^^^^^^^^^^^^^^^^^
Brian Curtine6242d72011-04-29 22:17:51 -0500906
907The :mod:`subprocess` module exposes the following constants.
908
909.. data:: STD_INPUT_HANDLE
910
911 The standard input device. Initially, this is the console input buffer,
912 ``CONIN$``.
913
914.. data:: STD_OUTPUT_HANDLE
915
916 The standard output device. Initially, this is the active console screen
917 buffer, ``CONOUT$``.
918
919.. data:: STD_ERROR_HANDLE
920
921 The standard error device. Initially, this is the active console screen
922 buffer, ``CONOUT$``.
923
924.. data:: SW_HIDE
925
926 Hides the window. Another window will be activated.
927
928.. data:: STARTF_USESTDHANDLES
929
930 Specifies that the :attr:`STARTUPINFO.hStdInput`,
Senthil Kumarana6bac952011-07-04 11:28:30 -0700931 :attr:`STARTUPINFO.hStdOutput`, and :attr:`STARTUPINFO.hStdError` attributes
Brian Curtine6242d72011-04-29 22:17:51 -0500932 contain additional information.
933
934.. data:: STARTF_USESHOWWINDOW
935
Senthil Kumarana6bac952011-07-04 11:28:30 -0700936 Specifies that the :attr:`STARTUPINFO.wShowWindow` attribute contains
Brian Curtine6242d72011-04-29 22:17:51 -0500937 additional information.
938
939.. data:: CREATE_NEW_CONSOLE
940
941 The new process has a new console, instead of inheriting its parent's
942 console (the default).
Brian Curtin73365dd2011-04-29 22:18:33 -0500943
Brian Curtin30401932011-04-29 22:20:57 -0500944.. data:: CREATE_NEW_PROCESS_GROUP
945
946 A :class:`Popen` ``creationflags`` parameter to specify that a new process
947 group will be created. This flag is necessary for using :func:`os.kill`
948 on the subprocess.
949
950 This flag is ignored if :data:`CREATE_NEW_CONSOLE` is specified.
951
Jamesb5d9e082017-11-08 14:18:59 +0000952.. data:: ABOVE_NORMAL_PRIORITY_CLASS
953
954 A :class:`Popen` ``creationflags`` parameter to specify that a new process
955 will have an above average priority.
956
957 .. versionadded:: 3.7
958
959.. data:: BELOW_NORMAL_PRIORITY_CLASS
960
961 A :class:`Popen` ``creationflags`` parameter to specify that a new process
962 will have a below average priority.
963
964 .. versionadded:: 3.7
965
966.. data:: HIGH_PRIORITY_CLASS
967
968 A :class:`Popen` ``creationflags`` parameter to specify that a new process
969 will have a high priority.
970
971 .. versionadded:: 3.7
972
973.. data:: IDLE_PRIORITY_CLASS
974
975 A :class:`Popen` ``creationflags`` parameter to specify that a new process
976 will have an idle (lowest) priority.
977
978 .. versionadded:: 3.7
979
980.. data:: NORMAL_PRIORITY_CLASS
981
982 A :class:`Popen` ``creationflags`` parameter to specify that a new process
983 will have an normal priority. (default)
984
985 .. versionadded:: 3.7
986
987.. data:: REALTIME_PRIORITY_CLASS
988
989 A :class:`Popen` ``creationflags`` parameter to specify that a new process
990 will have realtime priority.
991 You should almost never use REALTIME_PRIORITY_CLASS, because this interrupts
992 system threads that manage mouse input, keyboard input, and background disk
993 flushing. This class can be appropriate for applications that "talk" directly
994 to hardware or that perform brief tasks that should have limited interruptions.
995
996 .. versionadded:: 3.7
997
998.. data:: CREATE_NO_WINDOW
999
1000 A :class:`Popen` ``creationflags`` parameter to specify that a new process
Jules Lasne (jlasne)7e9ce4c2019-03-04 19:12:04 +01001001 will not create a window.
Jamesb5d9e082017-11-08 14:18:59 +00001002
1003 .. versionadded:: 3.7
1004
1005.. data:: DETACHED_PROCESS
1006
1007 A :class:`Popen` ``creationflags`` parameter to specify that a new process
1008 will not inherit its parent's console.
1009 This value cannot be used with CREATE_NEW_CONSOLE.
1010
1011 .. versionadded:: 3.7
1012
1013.. data:: CREATE_DEFAULT_ERROR_MODE
1014
1015 A :class:`Popen` ``creationflags`` parameter to specify that a new process
1016 does not inherit the error mode of the calling process. Instead, the new
1017 process gets the default error mode.
1018 This feature is particularly useful for multithreaded shell applications
1019 that run with hard errors disabled.
1020
1021 .. versionadded:: 3.7
1022
1023.. data:: CREATE_BREAKAWAY_FROM_JOB
1024
1025 A :class:`Popen` ``creationflags`` parameter to specify that a new process
1026 is not associated with the job.
1027
1028 .. versionadded:: 3.7
1029
Gregory P. Smith6e730002015-04-14 16:14:25 -07001030.. _call-function-trio:
1031
1032Older high-level API
1033--------------------
1034
1035Prior to Python 3.5, these three functions comprised the high level API to
1036subprocess. You can now use :func:`run` in many cases, but lots of existing code
1037calls these functions.
1038
Alex Gaynor368cf1d2017-05-25 22:28:17 -04001039.. function:: call(args, *, stdin=None, stdout=None, stderr=None, shell=False, cwd=None, timeout=None)
Gregory P. Smith6e730002015-04-14 16:14:25 -07001040
1041 Run the command described by *args*. Wait for command to complete, then
Berker Peksagbf1d4b62015-07-25 14:27:07 +03001042 return the :attr:`~Popen.returncode` attribute.
Gregory P. Smith6e730002015-04-14 16:14:25 -07001043
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001044 Code needing to capture stdout or stderr should use :func:`run` instead:
Gregory P. Smith6e730002015-04-14 16:14:25 -07001045
1046 run(...).returncode
1047
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001048 To suppress stdout or stderr, supply a value of :data:`DEVNULL`.
Gregory P. Smith6e730002015-04-14 16:14:25 -07001049
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001050 The arguments shown above are merely some common ones.
1051 The full function signature is the
Berker Peksagbf1d4b62015-07-25 14:27:07 +03001052 same as that of the :class:`Popen` constructor - this function passes all
1053 supplied arguments other than *timeout* directly through to that interface.
1054
Gregory P. Smith6e730002015-04-14 16:14:25 -07001055 .. note::
1056
1057 Do not use ``stdout=PIPE`` or ``stderr=PIPE`` with this
1058 function. The child process will block if it generates enough
1059 output to a pipe to fill up the OS pipe buffer as the pipes are
1060 not being read from.
1061
1062 .. versionchanged:: 3.3
1063 *timeout* was added.
1064
Alex Gaynor368cf1d2017-05-25 22:28:17 -04001065.. function:: check_call(args, *, stdin=None, stdout=None, stderr=None, shell=False, cwd=None, timeout=None)
Gregory P. Smith6e730002015-04-14 16:14:25 -07001066
1067 Run command with arguments. Wait for command to complete. If the return
1068 code was zero then return, otherwise raise :exc:`CalledProcessError`. The
1069 :exc:`CalledProcessError` object will have the return code in the
1070 :attr:`~CalledProcessError.returncode` attribute.
1071
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001072 Code needing to capture stdout or stderr should use :func:`run` instead:
Gregory P. Smith6e730002015-04-14 16:14:25 -07001073
1074 run(..., check=True)
1075
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001076 To suppress stdout or stderr, supply a value of :data:`DEVNULL`.
Gregory P. Smith6e730002015-04-14 16:14:25 -07001077
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001078 The arguments shown above are merely some common ones.
1079 The full function signature is the
Berker Peksagbf1d4b62015-07-25 14:27:07 +03001080 same as that of the :class:`Popen` constructor - this function passes all
1081 supplied arguments other than *timeout* directly through to that interface.
1082
Gregory P. Smith6e730002015-04-14 16:14:25 -07001083 .. note::
1084
1085 Do not use ``stdout=PIPE`` or ``stderr=PIPE`` with this
1086 function. The child process will block if it generates enough
1087 output to a pipe to fill up the OS pipe buffer as the pipes are
1088 not being read from.
1089
1090 .. versionchanged:: 3.3
1091 *timeout* was added.
1092
1093
Steve Dower050acae2016-09-06 20:16:17 -07001094.. function:: check_output(args, *, stdin=None, stderr=None, shell=False, \
Alex Gaynor368cf1d2017-05-25 22:28:17 -04001095 cwd=None, encoding=None, errors=None, \
Jakub Stasiak7432f092018-11-12 04:40:42 +01001096 universal_newlines=None, timeout=None, text=None)
Gregory P. Smith6e730002015-04-14 16:14:25 -07001097
1098 Run command with arguments and return its output.
1099
1100 If the return code was non-zero it raises a :exc:`CalledProcessError`. The
1101 :exc:`CalledProcessError` object will have the return code in the
1102 :attr:`~CalledProcessError.returncode` attribute and any output in the
1103 :attr:`~CalledProcessError.output` attribute.
1104
1105 This is equivalent to::
1106
1107 run(..., check=True, stdout=PIPE).stdout
1108
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001109 The arguments shown above are merely some common ones.
Berker Peksagbf1d4b62015-07-25 14:27:07 +03001110 The full function signature is largely the same as that of :func:`run` -
1111 most arguments are passed directly through to that interface.
1112 However, explicitly passing ``input=None`` to inherit the parent's
1113 standard input file handle is not supported.
1114
Gregory P. Smith6e730002015-04-14 16:14:25 -07001115 By default, this function will return the data as encoded bytes. The actual
1116 encoding of the output data may depend on the command being invoked, so the
1117 decoding to text will often need to be handled at the application level.
1118
Gregory P. Smith7a2e84c2019-03-23 00:40:28 -07001119 This behaviour may be overridden by setting *text*, *encoding*, *errors*,
1120 or *universal_newlines* to ``True`` as described in
1121 :ref:`frequently-used-arguments` and :func:`run`.
Gregory P. Smith6e730002015-04-14 16:14:25 -07001122
1123 To also capture standard error in the result, use
1124 ``stderr=subprocess.STDOUT``::
1125
1126 >>> subprocess.check_output(
1127 ... "ls non_existent_file; exit 0",
1128 ... stderr=subprocess.STDOUT,
1129 ... shell=True)
1130 'ls: non_existent_file: No such file or directory\n'
1131
1132 .. versionadded:: 3.1
1133
1134 .. versionchanged:: 3.3
1135 *timeout* was added.
1136
1137 .. versionchanged:: 3.4
Berker Peksagbf1d4b62015-07-25 14:27:07 +03001138 Support for the *input* keyword argument was added.
Brian Curtine6242d72011-04-29 22:17:51 -05001139
Brice Grosfc1ce812018-02-07 01:46:29 +01001140 .. versionchanged:: 3.6
1141 *encoding* and *errors* were added. See :func:`run` for details.
1142
Jakub Stasiak7432f092018-11-12 04:40:42 +01001143 .. versionadded:: 3.7
1144 *text* was added as a more readable alias for *universal_newlines*.
1145
1146
Benjamin Petersondcf97b92008-07-02 17:30:14 +00001147.. _subprocess-replacements:
1148
Ezio Melotti402f75d2012-11-08 10:07:10 +02001149Replacing Older Functions with the :mod:`subprocess` Module
1150-----------------------------------------------------------
Georg Brandl116aa622007-08-15 14:28:22 +00001151
Nick Coghlanc29248f2011-11-08 20:49:23 +10001152In this section, "a becomes b" means that b can be used as a replacement for a.
Georg Brandl116aa622007-08-15 14:28:22 +00001153
1154.. note::
1155
Nick Coghlanc29248f2011-11-08 20:49:23 +10001156 All "a" functions in this section fail (more or less) silently if the
1157 executed program cannot be found; the "b" replacements raise :exc:`OSError`
1158 instead.
Georg Brandl116aa622007-08-15 14:28:22 +00001159
Nick Coghlanc29248f2011-11-08 20:49:23 +10001160 In addition, the replacements using :func:`check_output` will fail with a
1161 :exc:`CalledProcessError` if the requested operation produces a non-zero
Serhiy Storchaka9e0ae532013-08-24 00:23:38 +03001162 return code. The output is still available as the
1163 :attr:`~CalledProcessError.output` attribute of the raised exception.
Nick Coghlanc29248f2011-11-08 20:49:23 +10001164
1165In the following examples, we assume that the relevant functions have already
Ezio Melotti402f75d2012-11-08 10:07:10 +02001166been imported from the :mod:`subprocess` module.
Georg Brandl116aa622007-08-15 14:28:22 +00001167
1168
1169Replacing /bin/sh shell backquote
1170^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1171
Martin Panter1050d2d2016-07-26 11:18:21 +02001172.. code-block:: bash
Georg Brandl116aa622007-08-15 14:28:22 +00001173
1174 output=`mycmd myarg`
Georg Brandl116aa622007-08-15 14:28:22 +00001175
Martin Panter1050d2d2016-07-26 11:18:21 +02001176becomes::
1177
1178 output = check_output(["mycmd", "myarg"])
Georg Brandl116aa622007-08-15 14:28:22 +00001179
Benjamin Petersonf10a79a2008-10-11 00:49:57 +00001180Replacing shell pipeline
1181^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +00001182
Martin Panter1050d2d2016-07-26 11:18:21 +02001183.. code-block:: bash
Georg Brandl116aa622007-08-15 14:28:22 +00001184
1185 output=`dmesg | grep hda`
Martin Panter1050d2d2016-07-26 11:18:21 +02001186
1187becomes::
1188
Georg Brandl116aa622007-08-15 14:28:22 +00001189 p1 = Popen(["dmesg"], stdout=PIPE)
1190 p2 = Popen(["grep", "hda"], stdin=p1.stdout, stdout=PIPE)
Gregory P. Smithe09d2f12011-02-05 21:47:25 +00001191 p1.stdout.close() # Allow p1 to receive a SIGPIPE if p2 exits.
Georg Brandl116aa622007-08-15 14:28:22 +00001192 output = p2.communicate()[0]
1193
Gregory P. Smithe09d2f12011-02-05 21:47:25 +00001194The p1.stdout.close() call after starting the p2 is important in order for p1
1195to receive a SIGPIPE if p2 exits before p1.
Georg Brandl116aa622007-08-15 14:28:22 +00001196
Nick Coghlanc29248f2011-11-08 20:49:23 +10001197Alternatively, for trusted input, the shell's own pipeline support may still
Martin Panter1050d2d2016-07-26 11:18:21 +02001198be used directly:
1199
1200.. code-block:: bash
Nick Coghlanc29248f2011-11-08 20:49:23 +10001201
1202 output=`dmesg | grep hda`
Martin Panter1050d2d2016-07-26 11:18:21 +02001203
1204becomes::
1205
Nick Coghlanc29248f2011-11-08 20:49:23 +10001206 output=check_output("dmesg | grep hda", shell=True)
1207
1208
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001209Replacing :func:`os.system`
1210^^^^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +00001211
1212::
1213
1214 sts = os.system("mycmd" + " myarg")
Nick Coghlanc29248f2011-11-08 20:49:23 +10001215 # becomes
1216 sts = call("mycmd" + " myarg", shell=True)
Georg Brandl116aa622007-08-15 14:28:22 +00001217
1218Notes:
1219
1220* Calling the program through the shell is usually not required.
1221
Georg Brandl116aa622007-08-15 14:28:22 +00001222A more realistic example would look like this::
1223
1224 try:
1225 retcode = call("mycmd" + " myarg", shell=True)
1226 if retcode < 0:
Collin Winterc79461b2007-09-01 23:34:30 +00001227 print("Child was terminated by signal", -retcode, file=sys.stderr)
Georg Brandl116aa622007-08-15 14:28:22 +00001228 else:
Collin Winterc79461b2007-09-01 23:34:30 +00001229 print("Child returned", retcode, file=sys.stderr)
Georg Brandl116aa622007-08-15 14:28:22 +00001230 except OSError as e:
Collin Winterc79461b2007-09-01 23:34:30 +00001231 print("Execution failed:", e, file=sys.stderr)
Georg Brandl116aa622007-08-15 14:28:22 +00001232
1233
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001234Replacing the :func:`os.spawn <os.spawnl>` family
1235^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +00001236
1237P_NOWAIT example::
1238
1239 pid = os.spawnlp(os.P_NOWAIT, "/bin/mycmd", "mycmd", "myarg")
1240 ==>
1241 pid = Popen(["/bin/mycmd", "myarg"]).pid
1242
1243P_WAIT example::
1244
1245 retcode = os.spawnlp(os.P_WAIT, "/bin/mycmd", "mycmd", "myarg")
1246 ==>
1247 retcode = call(["/bin/mycmd", "myarg"])
1248
1249Vector example::
1250
1251 os.spawnvp(os.P_NOWAIT, path, args)
1252 ==>
1253 Popen([path] + args[1:])
1254
1255Environment example::
1256
1257 os.spawnlpe(os.P_NOWAIT, "/bin/mycmd", "mycmd", "myarg", env)
1258 ==>
1259 Popen(["/bin/mycmd", "myarg"], env={"PATH": "/usr/bin"})
1260
1261
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001262
1263Replacing :func:`os.popen`, :func:`os.popen2`, :func:`os.popen3`
1264^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Georg Brandl116aa622007-08-15 14:28:22 +00001265
1266::
1267
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001268 (child_stdin, child_stdout) = os.popen2(cmd, mode, bufsize)
Georg Brandl116aa622007-08-15 14:28:22 +00001269 ==>
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001270 p = Popen(cmd, shell=True, bufsize=bufsize,
1271 stdin=PIPE, stdout=PIPE, close_fds=True)
1272 (child_stdin, child_stdout) = (p.stdin, p.stdout)
Georg Brandl116aa622007-08-15 14:28:22 +00001273
1274::
1275
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001276 (child_stdin,
1277 child_stdout,
1278 child_stderr) = os.popen3(cmd, mode, bufsize)
Georg Brandl116aa622007-08-15 14:28:22 +00001279 ==>
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001280 p = Popen(cmd, shell=True, bufsize=bufsize,
1281 stdin=PIPE, stdout=PIPE, stderr=PIPE, close_fds=True)
1282 (child_stdin,
1283 child_stdout,
1284 child_stderr) = (p.stdin, p.stdout, p.stderr)
1285
1286::
1287
1288 (child_stdin, child_stdout_and_stderr) = os.popen4(cmd, mode, bufsize)
1289 ==>
1290 p = Popen(cmd, shell=True, bufsize=bufsize,
1291 stdin=PIPE, stdout=PIPE, stderr=STDOUT, close_fds=True)
1292 (child_stdin, child_stdout_and_stderr) = (p.stdin, p.stdout)
1293
1294Return code handling translates as follows::
1295
1296 pipe = os.popen(cmd, 'w')
1297 ...
1298 rc = pipe.close()
Stefan Krahfc9e08d2010-07-14 10:16:11 +00001299 if rc is not None and rc >> 8:
Ezio Melotti985e24d2009-09-13 07:54:02 +00001300 print("There were some errors")
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001301 ==>
R David Murray17227a72015-09-04 10:01:19 -04001302 process = Popen(cmd, stdin=PIPE)
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001303 ...
1304 process.stdin.close()
1305 if process.wait() != 0:
Ezio Melotti985e24d2009-09-13 07:54:02 +00001306 print("There were some errors")
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001307
1308
1309Replacing functions from the :mod:`popen2` module
1310^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1311
1312.. note::
1313
1314 If the cmd argument to popen2 functions is a string, the command is executed
1315 through /bin/sh. If it is a list, the command is directly executed.
1316
1317::
1318
1319 (child_stdout, child_stdin) = popen2.popen2("somestring", bufsize, mode)
1320 ==>
R David Murrayae9d1932014-05-14 10:09:52 -04001321 p = Popen("somestring", shell=True, bufsize=bufsize,
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001322 stdin=PIPE, stdout=PIPE, close_fds=True)
1323 (child_stdout, child_stdin) = (p.stdout, p.stdin)
1324
1325::
1326
1327 (child_stdout, child_stdin) = popen2.popen2(["mycmd", "myarg"], bufsize, mode)
1328 ==>
1329 p = Popen(["mycmd", "myarg"], bufsize=bufsize,
1330 stdin=PIPE, stdout=PIPE, close_fds=True)
1331 (child_stdout, child_stdin) = (p.stdout, p.stdin)
1332
1333:class:`popen2.Popen3` and :class:`popen2.Popen4` basically work as
1334:class:`subprocess.Popen`, except that:
1335
1336* :class:`Popen` raises an exception if the execution fails.
1337
Jules Lasne (jlasne)7e9ce4c2019-03-04 19:12:04 +01001338* The *capturestderr* argument is replaced with the *stderr* argument.
Benjamin Peterson87c8d872009-06-11 22:54:11 +00001339
1340* ``stdin=PIPE`` and ``stdout=PIPE`` must be specified.
1341
1342* popen2 closes all file descriptors by default, but you have to specify
Gregory P. Smithf5604852010-12-13 06:45:02 +00001343 ``close_fds=True`` with :class:`Popen` to guarantee this behavior on
1344 all platforms or past Python versions.
Eli Bendersky046a7642011-04-15 07:23:26 +03001345
Nick Coghlanc29248f2011-11-08 20:49:23 +10001346
Nick Coghlanc29248f2011-11-08 20:49:23 +10001347Legacy Shell Invocation Functions
Nick Coghlan32e4a582011-11-08 21:50:58 +10001348---------------------------------
Nick Coghlanc29248f2011-11-08 20:49:23 +10001349
1350This module also provides the following legacy functions from the 2.x
1351``commands`` module. These operations implicitly invoke the system shell and
1352none of the guarantees described above regarding security and exception
1353handling consistency are valid for these functions.
1354
1355.. function:: getstatusoutput(cmd)
1356
Gregory P. Smith738b7d92017-09-06 17:39:23 -07001357 Return ``(exitcode, output)`` of executing *cmd* in a shell.
Nick Coghlanc29248f2011-11-08 20:49:23 +10001358
Tim Golden60798142013-11-05 12:57:25 +00001359 Execute the string *cmd* in a shell with :meth:`Popen.check_output` and
Gregory P. Smith738b7d92017-09-06 17:39:23 -07001360 return a 2-tuple ``(exitcode, output)``. The locale encoding is used;
Tim Golden60798142013-11-05 12:57:25 +00001361 see the notes on :ref:`frequently-used-arguments` for more details.
Tim Golden3a2abb52013-11-03 18:24:50 +00001362
1363 A trailing newline is stripped from the output.
Gregory P. Smith738b7d92017-09-06 17:39:23 -07001364 The exit code for the command can be interpreted as the return code
1365 of subprocess. Example::
Nick Coghlanc29248f2011-11-08 20:49:23 +10001366
1367 >>> subprocess.getstatusoutput('ls /bin/ls')
1368 (0, '/bin/ls')
1369 >>> subprocess.getstatusoutput('cat /bin/junk')
Gregory P. Smith738b7d92017-09-06 17:39:23 -07001370 (1, 'cat: /bin/junk: No such file or directory')
Nick Coghlanc29248f2011-11-08 20:49:23 +10001371 >>> subprocess.getstatusoutput('/bin/junk')
Gregory P. Smith738b7d92017-09-06 17:39:23 -07001372 (127, 'sh: /bin/junk: not found')
1373 >>> subprocess.getstatusoutput('/bin/kill $$')
1374 (-15, '')
Nick Coghlanc29248f2011-11-08 20:49:23 +10001375
Cheryl Sabella2d6097d2018-10-12 10:55:20 -04001376 .. availability:: POSIX & Windows.
R David Murray95b696a2014-03-07 20:04:17 -05001377
1378 .. versionchanged:: 3.3.4
Gregory P. Smith738b7d92017-09-06 17:39:23 -07001379 Windows support was added.
1380
1381 The function now returns (exitcode, output) instead of (status, output)
Xiang Zhang7d161722018-09-22 04:18:20 +08001382 as it did in Python 3.3.3 and earlier. exitcode has the same value as
1383 :attr:`~Popen.returncode`.
Nick Coghlanc29248f2011-11-08 20:49:23 +10001384
1385
1386.. function:: getoutput(cmd)
1387
1388 Return output (stdout and stderr) of executing *cmd* in a shell.
1389
Xiang Zhang7d161722018-09-22 04:18:20 +08001390 Like :func:`getstatusoutput`, except the exit code is ignored and the return
Nick Coghlanc29248f2011-11-08 20:49:23 +10001391 value is a string containing the command's output. Example::
1392
1393 >>> subprocess.getoutput('ls /bin/ls')
1394 '/bin/ls'
1395
Cheryl Sabella2d6097d2018-10-12 10:55:20 -04001396 .. availability:: POSIX & Windows.
R David Murray95b696a2014-03-07 20:04:17 -05001397
1398 .. versionchanged:: 3.3.4
1399 Windows support added
Nick Coghlanc29248f2011-11-08 20:49:23 +10001400
Nick Coghlan32e4a582011-11-08 21:50:58 +10001401
Eli Bendersky046a7642011-04-15 07:23:26 +03001402Notes
1403-----
1404
1405.. _converting-argument-sequence:
1406
1407Converting an argument sequence to a string on Windows
1408^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1409
1410On Windows, an *args* sequence is converted to a string that can be parsed
1411using the following rules (which correspond to the rules used by the MS C
1412runtime):
1413
14141. Arguments are delimited by white space, which is either a
1415 space or a tab.
1416
14172. A string surrounded by double quotation marks is
1418 interpreted as a single argument, regardless of white space
1419 contained within. A quoted string can be embedded in an
1420 argument.
1421
14223. A double quotation mark preceded by a backslash is
1423 interpreted as a literal double quotation mark.
1424
14254. Backslashes are interpreted literally, unless they
1426 immediately precede a double quotation mark.
1427
14285. If backslashes immediately precede a double quotation mark,
1429 every pair of backslashes is interpreted as a literal
1430 backslash. If the number of backslashes is odd, the last
1431 backslash escapes the next double quotation mark as
1432 described in rule 3.
1433
Eli Benderskyd2112312011-04-15 07:26:28 +03001434
Éric Araujo9bce3112011-07-27 18:29:31 +02001435.. seealso::
1436
1437 :mod:`shlex`
1438 Module which provides function to parse and escape command lines.