diff options
author | Raymond Hettinger <python@rcn.com> | 2010-12-08 11:19:45 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2010-12-08 11:19:45 (GMT) |
commit | b1ff4024a86bbaa6be9d639cbc5d3d373e554d0a (patch) | |
tree | 2f43f9f9c0bfd35463a74eb710a7dd5a8c406be7 | |
parent | 2ffa671de77d9b3ca8f43669ae62a1913174b8e0 (diff) | |
download | cpython-b1ff4024a86bbaa6be9d639cbc5d3d373e554d0a.zip cpython-b1ff4024a86bbaa6be9d639cbc5d3d373e554d0a.tar.gz cpython-b1ff4024a86bbaa6be9d639cbc5d3d373e554d0a.tar.bz2 |
Example of argparge with subparsers.
-rw-r--r-- | Doc/whatsnew/3.2.rst | 29 |
1 files changed, 24 insertions, 5 deletions
diff --git a/Doc/whatsnew/3.2.rst b/Doc/whatsnew/3.2.rst index 38d2feb..1bc8093 100644 --- a/Doc/whatsnew/3.2.rst +++ b/Doc/whatsnew/3.2.rst @@ -84,10 +84,10 @@ positional arguments (not just options), subcommands, required options and other common patterns of specifying and validating options. This module has already has wide-spread success in the community as a -third-party module. Being more fully featured than its predecessor, -:mod:`argparse`, is now the preferred module for command-line processing. The -older module is still being kept available because of the substantial amount of -legacy code that depends on it. +third-party module. Being more fully featured than its predecessor, the +:mod:`argparse` module is now the preferred module for command-line processing. +The older module is still being kept available because of the substantial amount +of legacy code that depends on it. Here's an annotated example parser showing features like limiting results to a set of choices, specifying a *metavar* in the help screen, validating that one @@ -113,7 +113,7 @@ Example of calling the parser on a command string:: >>> cmd = 'deploy sneezy.example.com sleepy.example.com -u skycaptain' >>> result = parser.parse_args(cmd.split()) - >>> # parsed variable are stored in the attributes + >>> # parsed variables are stored in the attributes >>> result.action 'deploy' >>> result.targets @@ -140,6 +140,25 @@ Example of the parser's automatically generated help:: Tested on Solaris and Linux +An especially nice :mod:`argparse` feature is the ability to define subparsers, +each with their own argument patterns and help displays:: + + import argparse + parser = argparse.ArgumentParser(prog='HELM') + subparsers = parser.add_subparsers() + + parser_l = subparsers.add_parser('launch', help='Launch Control') # first subgroup + parser_l.add_argument('-m', '--missles', action='store_true') + parser_l.add_argument('-t', '--torpedos', action='store_true') + + parser_m = subparsers.add_parser('move', help='Move Vessel') # second subgroup + parser_m.add_argument('-c', '--course', type=int, required=True) + parser_m.add_argument('-s', '--speed', type=int, default=0) + + $ ./helm.py --help # top level help (launch and move) + $ ./helm.py launch --help # help for launch options + $ ./helm.py launch --missiles # set missiles=True and torpedos=False + $ ./helm.py move --course 180 --speed 5 # set movement parameters .. seealso:: |