Kaydet (Commit) 74bd9cf7 authored tarafından Steven Bethard's avatar Steven Bethard

argparse documentation updates (including updates to optparse and getopt…

argparse documentation updates (including updates to optparse and getopt documentation that were promised in the PEP)
üst 151973e1
...@@ -672,8 +672,8 @@ command-line args should be handled. The supported actions are: ...@@ -672,8 +672,8 @@ command-line args should be handled. The supported actions are:
>>> import argparse >>> import argparse
>>> parser = argparse.ArgumentParser(prog='PROG') >>> parser = argparse.ArgumentParser(prog='PROG')
>>> parser.add_argument('-v', '--version', action='version', version='%(prog)s 2.0') >>> parser.add_argument('--version', action='version', version='%(prog)s 2.0')
>>> parser.parse_args(['-v']) >>> parser.parse_args(['--version'])
PROG 2.0 PROG 2.0
You can also specify an arbitrary action by passing an object that implements You can also specify an arbitrary action by passing an object that implements
...@@ -1725,3 +1725,6 @@ A partial upgrade path from optparse to argparse: ...@@ -1725,3 +1725,6 @@ A partial upgrade path from optparse to argparse:
* Replace strings with implicit arguments such as ``%default`` or ``%prog`` with * Replace strings with implicit arguments such as ``%default`` or ``%prog`` with
the standard python syntax to use dictionaries to format strings, that is, the standard python syntax to use dictionaries to format strings, that is,
``%(default)s`` and ``%(prog)s``. ``%(default)s`` and ``%(prog)s``.
* Replace the OptionParser constructor ``version`` argument with a call to
``parser.add_argument('--version', action='version', version='<the version>')``
...@@ -6,6 +6,12 @@ ...@@ -6,6 +6,12 @@
:synopsis: Portable parser for command line options; support both short and long option :synopsis: Portable parser for command line options; support both short and long option
names. names.
.. note::
The :mod:`getopt` module is a parser for command line options whose API is
designed to be familiar to users of the C :cfunc:`getopt` function. Users who
are unfamiliar with the C :cfunc:`getopt` function or who would like to write
less code and get better help and error messages should consider using the
:mod:`argparse` module instead.
This module helps scripts to parse the command line arguments in ``sys.argv``. This module helps scripts to parse the command line arguments in ``sys.argv``.
It supports the same conventions as the Unix :cfunc:`getopt` function (including It supports the same conventions as the Unix :cfunc:`getopt` function (including
...@@ -142,9 +148,21 @@ In a script, typical usage is something like this:: ...@@ -142,9 +148,21 @@ In a script, typical usage is something like this::
if __name__ == "__main__": if __name__ == "__main__":
main() main()
Note that an equivalent command line interface could be produced with less code
and more informative help and error messages by using the :mod:`argparse` module::
import argparse
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('-o', '--output')
parser.add_argument('-v', dest='verbose', action='store_true')
args = parser.parse_args()
# ... do something with args.output ...
# ... do something with args.verbose ..
.. seealso:: .. seealso::
Module :mod:`optparse` Module :mod:`argparse`
More object-oriented command line option parsing. Alternative command line option and argument parsing library.
...@@ -3,8 +3,13 @@ ...@@ -3,8 +3,13 @@
.. module:: optparse .. module:: optparse
:synopsis: Command-line option parsing library. :synopsis: Command-line option parsing library.
.. moduleauthor:: Greg Ward <gward@python.net> :deprecated:
.. deprecated:: 2.7
The :mod:`optparse` module is deprecated and will not be developed further;
development will continue with the :mod:`argparse` module.
.. moduleauthor:: Greg Ward <gward@python.net>
.. versionadded:: 2.3 .. versionadded:: 2.3
......
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