





похоже, что для создания справки используется метавар: http://www.python.org/doc/2.5.2/lib/optparse-generating-help.html
Как говорит @Guillaume, он используется для создания справки. Если вы хотите иметь параметр, который принимает аргумент, например имя файла, вы можете добавить параметр metavar к вызову add_option, чтобы ваше предпочтительное имя / дескриптор аргумента выводилось в справочном сообщении. От текущая документация модуля:
usage = "usage: %prog [options] arg1 arg2"
parser = OptionParser(usage=usage)
parser.add_option("-f", "--filename",
metavar = "FILE", help = "write output to FILE"),
дала бы такую помощь:
usage: <yourscript> [options] arg1 arg2
options:
-f FILE, --filename=FILE
«ФАЙЛ» после «-f» и «--filename» происходит от метавара.
metavar - это переменная, используемая для печати на экране после опции. Обычно для ввода предложения после опции используются FILE, INT или STRING для пользователя. Без metavaroptparse будет печатать значение dest после того, как вы добавили параметр.
Есть еще одно значимое использование метавары, когда нужно использовать «dest» в качестве поискового тега аргумента, но замаскировать справочное сообщение метаваром. (Например, иногда бывает удобно при использовании субпарсеров). (Как указано в комментарии С.Лотт).
parser.add_argument(
'my_fancy_tag',
help='Specify destination',
metavar='helpful_message'
)
или в равной степени
parser.add_argument(
dest='my_fancy_tag',
help='Specify destination',
metavar='helpful_message'
)
Помощь покажет метавар:
./parse.py -h usage: parser [-h] destination
positional arguments:
helpful_message Specify destination
но dest будет хранить fancy_tag в пространстве имен:
./parse.py test
Namespace(my_fancy_tag='test')
metavar = "Helpname" настраивает справочное сообщение с полезным именем; отличается от dest = "name". Dest = "name" может быть бесполезен для пользователей.