Kaydet (Commit) 5973e4d0 authored tarafından R. David Murray's avatar R. David Murray

Merged revisions 77943,77959-77960 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r77943 | r.david.murray | 2010-02-03 08:36:23 -0500 (Wed, 03 Feb 2010) | 2 lines

  Explicitly mention the default value for formatdate's usegmt parameter.
........
  r77959 | nick.coghlan | 2010-02-04 07:43:58 -0500 (Thu, 04 Feb 2010) | 1 line

  Issue 6760: Clarify args handling for subprocess.Popen. Patch by Chris Rebert
........
  r77960 | r.david.murray | 2010-02-04 11:33:31 -0500 (Thu, 04 Feb 2010) | 2 lines

  Add Chris Rebert to ACKS for issue 6760 Popen doc improvements.
........
üst ddb5e70e
...@@ -102,7 +102,7 @@ There are several useful utilities provided in the :mod:`email.utils` module: ...@@ -102,7 +102,7 @@ There are several useful utilities provided in the :mod:`email.utils` module:
Optional *usegmt* is a flag that when ``True``, outputs a date string with the Optional *usegmt* is a flag that when ``True``, outputs a date string with the
timezone as an ascii string ``GMT``, rather than a numeric ``-0000``. This is timezone as an ascii string ``GMT``, rather than a numeric ``-0000``. This is
needed for some protocols (such as HTTP). This only applies when *localtime* is needed for some protocols (such as HTTP). This only applies when *localtime* is
``False``. ``False``. The default is ``False``.
.. function:: make_msgid(idstring=None) .. function:: make_msgid(idstring=None)
......
...@@ -42,13 +42,38 @@ This module defines one class called :class:`Popen`: ...@@ -42,13 +42,38 @@ This module defines one class called :class:`Popen`:
On Unix, with *shell=False* (default): In this case, the Popen class uses On Unix, with *shell=False* (default): In this case, the Popen class uses
:meth:`os.execvp` to execute the child program. *args* should normally be a :meth:`os.execvp` to execute the child program. *args* should normally be a
sequence. A string will be treated as a sequence with the string as the only sequence. If a string is specified for *args*, it will be used as the name
item (the program to execute). or path of the program to execute; this will only work if the program is
being given no arguments.
On Unix, with *shell=True*: If args is a string, it specifies the command string .. note::
to execute through the shell. If *args* is a sequence, the first item specifies
the command string, and any additional items will be treated as additional shell :meth:`shlex.split` can be useful when determining the correct
arguments. tokenization for *args*, especially in complex cases::
>>> import shlex, subprocess
>>> command_line = raw_input()
/bin/vikings -input eggs.txt -output "spam spam.txt" -cmd "echo '$MONEY'"
>>> args = shlex.split(command_line)
>>> print(args)
['/bin/vikings', '-input', 'eggs.txt', '-output', 'spam spam.txt', '-cmd', "echo '$MONEY'"]
>>> p = subprocess.Popen(args) # Success!
Note in particular that options (such as *-input*) and arguments (such
as *eggs.txt*) that are separated by whitespace in the shell go in separate
list elements, while arguments that need quoting or backslash escaping when
used in the shell (such as filenames containing spaces or the *echo* command
shown above) are single list elements.
On Unix, with *shell=True*: If args is a string, it specifies the command
string to execute through the shell. This means that the string must be
formatted exactly as it would be when typed at the shell prompt. This
includes, for example, quoting or backslash escaping filenames with spaces in
them. If *args* is a sequence, the first item specifies the command string, and
any additional items will be treated as additional arguments to the shell
itself. That is to say, *Popen* does the equivalent of::
Popen(['/bin/sh', '-c', args[0], args[1], ...])
On Windows: the :class:`Popen` class uses CreateProcess() to execute the child On Windows: the :class:`Popen` class uses CreateProcess() to execute the child
program, which operates on strings. If *args* is a sequence, it will be program, which operates on strings. If *args* is a sequence, it will be
......
...@@ -616,6 +616,7 @@ Brodie Rao ...@@ -616,6 +616,7 @@ Brodie Rao
Antti Rasinen Antti Rasinen
Eric Raymond Eric Raymond
Edward K. Ream Edward K. Ream
Chris Rebert
Marc Recht Marc Recht
John Redford John Redford
Terry Reedy Terry Reedy
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment