add_mutually_exclusive_group
グループ全体を相互に排他的にするわけではありません。グループ内のオプションを相互に排他的にします。
あなたが探しているのはsubcommandsです。prog の代わりに [ -a xxxx | [-b yyy -c zzz]] の場合:
prog
command 1
-a: ...
command 2
-b: ...
-c: ...
引数の最初のセットで呼び出すには:
prog command_1 -a xxxx
2 番目の引数セットを使用して呼び出すには、次のようにします。
prog command_2 -b yyyy -c zzzz
サブコマンドの引数を定位置として設定することもできます。
prog command_1 xxxx
git や svn のようなもの:
git commit -am
git merge develop
実施例
# create the top-level parser
parser = argparse.ArgumentParser(prog='PROG')
parser.add_argument('--foo', action='store_true', help='help for foo arg.')
subparsers = parser.add_subparsers(help='help for subcommand', dest="subcommand")
# create the parser for the "command_1" command
parser_a = subparsers.add_parser('command_1', help='command_1 help')
parser_a.add_argument('a', type=str, help='help for bar, positional')
# create the parser for the "command_2" command
parser_b = subparsers.add_parser('command_2', help='help for command_2')
parser_b.add_argument('-b', type=str, help='help for b')
parser_b.add_argument('-c', type=str, action='store', default='', help='test')
試して
>>> parser.print_help()
usage: PROG [-h] [--foo] {command_1,command_2} ...
positional arguments:
{command_1,command_2}
help for subcommand
command_1 command_1 help
command_2 help for command_2
optional arguments:
-h, --help show this help message and exit
--foo help for foo arg.
>>>
>>> parser.parse_args(['command_1', 'working'])
Namespace(subcommand='command_1', a='working', foo=False)
>>> parser.parse_args(['command_1', 'wellness', '-b x'])
usage: PROG [-h] [--foo] {command_1,command_2} ...
PROG: error: unrecognized arguments: -b x
幸運を。