Skip to content

argparse: how to allow option values starting with dash #138950

@Celelibi

Description

@Celelibi

Documentation

The difference between nargs=None and nargs=1 should probably be explained in the docs in the section about arguments containing -.
Using nargs=1 actually allows to work around some issues with having an option value starting with a dash. Which has been a long standing issue with argparse as shown with the issue #53580.

Here is an example of the difference:

>>> parser = argparse.ArgumentParser()
>>> parser.add_argument("--nargs-is-1", nargs=1)
>>> parser.parse_args(["--nargs-is-1", "-3,5-10"])
Namespace(nargs_is_none=None, nargs_is_1=['-3,5-10'])
>>> parser.add_argument("--nargs-is-none")
>>> parser.parse_args(["--nargs-is-none", "-3,5-10"])
usage: [-h] [--nargs-is-none NARGS_IS_NONE] [--nargs-is-1 NARGS_IS_1]
: error: argument --nargs-is-none: expected one argument

This trick, however, only covers the case where the number of arguments to gobble up is fixed. People wanting a variable number of arguments to their options would need a more involved disambiguation technique that argparse is incapable of for now. (Although I guess something could be implemented by labeling ambiguous arguments as ambiguous and introduce values of nargs for different treatment of those. But that's beside the scope of this issue.)

Incidentally, this trick has been made to work only one year ago by the commit 3f27153. Not sure if that was an intended consequence, but now it works and I'm here for it. :)

That documentation section (arguments containing -) suggests that argparse uses a heuristics to determine whether an argument is positional or optional. Maybe the gist of the heuristics could be laid out on so that users don't have to guess or read the code to get argparse to behave the way they want?

Metadata

Metadata

Labels

3.13bugs and security fixesstdlibStandard Library Python modules in the Lib/ directorytype-bugAn unexpected behavior, bug, or error

Projects

Status

No status

Status

Todo

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions