diff options
author | Eli Bendersky <eliben@gmail.com> | 2013-12-02 13:49:54 (GMT) |
---|---|---|
committer | Eli Bendersky <eliben@gmail.com> | 2013-12-02 13:49:54 (GMT) |
commit | f3114532e4a59fff647f2edb777351b3a4839095 (patch) | |
tree | 41c14308c593fc2040c636187e5f69eef3f02699 /Doc | |
parent | 22d0418f71504c6501ec73e9d09f8b2bd9e8fdc1 (diff) | |
download | cpython-f3114532e4a59fff647f2edb777351b3a4839095.zip cpython-f3114532e4a59fff647f2edb777351b3a4839095.tar.gz cpython-f3114532e4a59fff647f2edb777351b3a4839095.tar.bz2 |
Issue #19814: Clarify argparse's docs w.r.t prefix matching
Diffstat (limited to 'Doc')
-rw-r--r-- | Doc/library/argparse.rst | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/Doc/library/argparse.rst b/Doc/library/argparse.rst index 0b18c6d..b686c44 100644 --- a/Doc/library/argparse.rst +++ b/Doc/library/argparse.rst @@ -1371,12 +1371,14 @@ argument:: >>> parser.parse_args(['--', '-f']) Namespace(foo='-f', one=None) +.. _prefix-matching: -Argument abbreviations -^^^^^^^^^^^^^^^^^^^^^^ +Argument abbreviations (prefix matching) +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The :meth:`~ArgumentParser.parse_args` method allows long options to be -abbreviated if the abbreviation is unambiguous:: +abbreviated to a prefix, if the abbreviation is unambiguous (the prefix matches +a unique option):: >>> parser = argparse.ArgumentParser(prog='PROG') >>> parser.add_argument('-bacon') @@ -1852,6 +1854,12 @@ the populated namespace and the list of remaining argument strings. >>> parser.parse_known_args(['--foo', '--badger', 'BAR', 'spam']) (Namespace(bar='BAR', foo=True), ['--badger', 'spam']) +.. warning:: + :ref:`Prefix matching <prefix-matching>` rules apply to + :meth:`parse_known_args`. The parser may consume an option even if it's just + a prefix of one of its known options, instead of leaving it in the remaining + arguments list. + Customizing file parsing ^^^^^^^^^^^^^^^^^^^^^^^^ |