diff options
author | Barry Warsaw <barry@python.org> | 2012-09-25 14:37:58 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2012-09-25 14:37:58 (GMT) |
commit | 1dedd0a4a4b88eeabb95af4b372a447b4d41b223 (patch) | |
tree | 05e843bdad2a63dfba349b772e68a2c2b4b2e4cc | |
parent | df12f2bbb6d7d2a26fc10072ead199b3a19c6623 (diff) | |
download | cpython-1dedd0a4a4b88eeabb95af4b372a447b4d41b223.zip cpython-1dedd0a4a4b88eeabb95af4b372a447b4d41b223.tar.gz cpython-1dedd0a4a4b88eeabb95af4b372a447b4d41b223.tar.bz2 |
- Issue #15935: Clarification of argparse docs, re: add_argument() type and
default arguments. Patch contributed by Chris Jerdonek.
-rw-r--r-- | Doc/library/argparse.rst | 14 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
2 files changed, 17 insertions, 0 deletions
diff --git a/Doc/library/argparse.rst b/Doc/library/argparse.rst index 1313e4b..5273e9b 100644 --- a/Doc/library/argparse.rst +++ b/Doc/library/argparse.rst @@ -904,6 +904,17 @@ was not present at the command line:: >>> parser.parse_args(''.split()) Namespace(foo=42) +If the ``default`` value is a string, the parser parses the value as if it +were a command-line argument. In particular, the parser applies any type_ +conversion argument, if provided, before setting the attribute on the +:class:`Namespace` return value. Otherwise, the parser uses the value as is:: + + >>> parser = argparse.ArgumentParser() + >>> parser.add_argument('--length', default='10', type=int) + >>> parser.add_argument('--width', default=10.5, type=int) + >>> parser.parse_args() + Namespace(length=10, width=10.5) + For positional arguments with nargs_ equal to ``?`` or ``*``, the ``default`` value is used when no command-line argument was present:: @@ -942,6 +953,9 @@ types and functions can be used directly as the value of the ``type`` argument:: >>> parser.parse_args('2 temp.txt'.split()) Namespace(bar=<_io.TextIOWrapper name='temp.txt' encoding='UTF-8'>, foo=2) +See the section on the default_ keyword argument for information on when the +``type`` argument is applied to default arguments. + To ease the use of various types of files, the argparse module provides the factory FileType which takes the ``mode=`` and ``bufsize=`` arguments of the :func:`open` function. For example, ``FileType('w')`` can be used to create a @@ -589,6 +589,9 @@ Build Documentation ------------- +- Issue #15935: Clarification of argparse docs, re: add_argument() type and + default arguments. Patch contributed by Chris Jerdonek. + - Issue #11964: Document a change in v3.2 to the behavior of the indent parameter of json encoding operations. |