Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
37751967
Commit
37751967
authored
Aug 03, 2014
by
Jason R. Coombs
Browse files
Options
Browse Files
Download
Plain Diff
Issue #13540: Merge changes from 3.2
parents
d4273d3b
2dc80523
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
53 additions
and
19 deletions
+53
-19
Doc/library/argparse.rst
Doc/library/argparse.rst
+53
-19
No files found.
Doc/library/argparse.rst
View file @
37751967
...
@@ -683,7 +683,7 @@ action
...
@@ -683,7 +683,7 @@ action
actions can do just about anything with the command-line arguments associated with
actions can do just about anything with the command-line arguments associated with
them, though most actions simply add an attribute to the object returned by
them, though most actions simply add an attribute to the object returned by
:meth:`~ArgumentParser.parse_args`. The ``action`` keyword argument specifies
:meth:`~ArgumentParser.parse_args`. The ``action`` keyword argument specifies
how the command-line arguments should be handled. The supp
ort
ed actions are:
how the command-line arguments should be handled. The supp
li
ed actions are:
* ``'store'`` - This just stores the argument's value. This is the default
* ``'store'`` - This just stores the argument's value. This is the default
action. For example::
action. For example::
...
@@ -757,28 +757,18 @@ how the command-line arguments should be handled. The supported actions are:
...
@@ -757,28 +757,18 @@ how the command-line arguments should be handled. The supported actions are:
>>> parser.parse_args(['--version'])
>>> parser.parse_args(['--version'])
PROG 2.0
PROG 2.0
You can also specify an arbitrary action by passing an object that implements
You may also specify an arbitrary action by passing an Action subclass or
the Action API. The easiest way to do this is to extend
other object that implements the same interface. The recommended way to do
:class:`argparse.Action`, supplying an appropriate ``__call__`` method. The
this is to extend :class:`Action`, overriding the ``__call__`` method
``__call__`` method should accept four parameters:
and optionally the ``__init__`` method.
* ``parser`` - The ArgumentParser object which contains this action.
* ``namespace`` - The :class:`Namespace` object that will be returned by
:meth:`~ArgumentParser.parse_args`. Most actions add an attribute to this
object.
* ``values`` - The associated command-line arguments, with any type conversions
applied. (Type conversions are specified with the type_ keyword argument to
:meth:`~ArgumentParser.add_argument`.)
* ``option_string`` - The option string that was used to invoke this action.
The ``option_string`` argument is optional, and will be absent if the action
is associated with a positional argument.
An example of a custom action::
An example of a custom action::
>>> class FooAction(argparse.Action):
>>> class FooAction(argparse.Action):
... def __init__(self, option_strings, dest, nargs=None, **kwargs):
... if nargs is not None:
... raise ValueError("nargs not allowed")
... super(FooAction, self).__init__(option_strings, dest, **kwargs)
... def __call__(self, parser, namespace, values, option_string=None):
... def __call__(self, parser, namespace, values, option_string=None):
... print('%r %r %r' % (namespace, values, option_string))
... print('%r %r %r' % (namespace, values, option_string))
... setattr(namespace, self.dest, values)
... setattr(namespace, self.dest, values)
...
@@ -792,6 +782,7 @@ An example of a custom action::
...
@@ -792,6 +782,7 @@ An example of a custom action::
>>> args
>>> args
Namespace(bar='1', foo='2')
Namespace(bar='1', foo='2')
For more details, see :class:`Action`.
nargs
nargs
^^^^^
^^^^^
...
@@ -1238,6 +1229,49 @@ behavior::
...
@@ -1238,6 +1229,49 @@ behavior::
>>> parser.parse_args('--foo XXX'.split())
>>> parser.parse_args('--foo XXX'.split())
Namespace(bar='XXX')
Namespace(bar='XXX')
Action classes
^^^^^^^^^^^^^^
Action classes implement the Action API, a callable which returns a callable
which processes arguments from the command-line. Any object which follows
this API may be passed as the ``action`` parameter to
:method:`add_argument`.
.. class:: Action(option_strings, dest, nargs=None, const=None, default=None,
type=None, choices=None, required=False, help=None,
metavar=None)
Action objects are used by an ArgumentParser to represent the information
needed to parse a single argument from one or more strings from the
command line. The Action class must accept the two positional arguments
plus any keyword arguments passed to :method:`ArgumentParser.add_argument`
except for the ``action`` itself.
Instances of Action (or return value of any callable to the ``action``
parameter) should have attributes "dest", "option_strings", "default", "type",
"required", "help", etc. defined. The easiest way to ensure these attributes
are defined is to call ``Action.__init__``.
Action instances should be callable, so subclasses must override the
``__call__`` method, which should accept four parameters:
* ``parser`` - The ArgumentParser object which contains this action.
* ``namespace`` - The :class:`Namespace` object that will be returned by
:meth:`~ArgumentParser.parse_args`. Most actions add an attribute to this
object using :func:`setattr`.
* ``values`` - The associated command-line arguments, with any type conversions
applied. Type conversions are specified with the type_ keyword argument to
:meth:`~ArgumentParser.add_argument`.
* ``option_string`` - The option string that was used to invoke this action.
The ``option_string`` argument is optional, and will be absent if the action
is associated with a positional argument.
The ``__call__`` method may perform arbitrary actions, but will typically set
attributes on the ``namespace`` based on ``dest`` and ``values``.
The parse_args() method
The parse_args() method
-----------------------
-----------------------
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment