不,不是没有丑陋的黑客。
@Vladimir 发布的代码片段,我想这不是您想要的。这样做的实际代码是:
def _get_option_tuples(self, option_string):
...
if option_string.startswith(option_prefix):
...
看检查是startswith
不是==
。
而且您始终可以扩展argparse.ArgumentParser
以提供您自己的_get_option_tuples(self, option_string)
来改变这种行为。我只是通过替换两次出现的option_string.startswith(option_prefix)
tooption_string == option_prefix
和:
>>> parser = my_argparse.MyArgparse
>>> parser = my_argparse.MyArgparse()
>>> parser.add_argument('--send', action='store_true')
_StoreTrueAction(option_strings=['--send'], dest='send', nargs=0, const=True, default=False, type=None, choices=None, help=None, metavar=None)
>>> parser.parse_args(['--se'])
usage: [-h] [--send]
: error: unrecognized arguments: --se
一个警告
该方法_get_option_tuples
以 为前缀_
,通常表示 python 中的私有方法。覆盖私有也不是一个好主意。