desbma added the comment:

> With my type function, the string input is converted to an enum object and 
> that is stored in the Namespace.  You can't be any more direct than that.

Yes I know, but in that case it's missing the autogenerated help message with 
the possible choices.

I know I can generate it manually, it just does not feel right for doing 
something so simple. IMO the goal of argparse is to unload the burden of 
checking/validating parameters manually, generating help messages with 
default/possible values, etc.

Your solution with a dictionnary is similar to what I currently use and wrote 
in my example, with the added drawback that the keys are randomly ordered in 
the help message, unless I use OrderedDict (one more import and more 
boilerplate code).

Each approach has its drawbacks, unless you write some additional code to 
workaround each limitation.

In a perfect world, argparse would:
* only show to the user the enum names, and use it in help/error messages, 
possible choice set, etc.
* after parsing, set the real enum value in the namespace
* and most importantly: to do that, don't require more code than just passing 
the enum

----------

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue25061>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to