add_mutually_exclusive_group
não torna um grupo inteiro mutuamente exclusivo. Isso torna as opções dentro do grupo mutuamente exclusivas.
O que você está procurando são subcomandos . Em vez de prog [-a xxxx | [-b yyy -c zzz]], você teria:
prog
command 1
-a: ...
command 2
-b: ...
-c: ...
Para invocar com o primeiro conjunto de argumentos:
prog command_1 -a xxxx
Para invocar com o segundo conjunto de argumentos:
prog command_2 -b yyyy -c zzzz
Você também pode definir os argumentos do subcomando como posicionais.
prog command_1 xxxx
Mais ou menos como git ou svn:
git commit -am
git merge develop
Exemplo de Trabalho
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')
parser_a = subparsers.add_parser('command_1', help='command_1 help')
parser_a.add_argument('a', type=str, help='help for bar, positional')
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')
Teste-o
>>> 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(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
Boa sorte.