29

以下の例に示すように、getopt または optparse を使用して、1 つのオプションに対して複数の値を取得することは可能ですか?

./hello_world -c arg1 arg2 arg3 -b arg4 arg5 arg6 arg7

各オプション (-c、-b) の実際の値の数は、1 または 100 のいずれかになる可能性があることに注意してください。 ./hello_world -c "arg1 arg2 arg3" -b "arg4 arg5 arg6 arg7"

これは不可能かもしれない (そしておそらく POSIX に違反している) ように思えますが、間違っている場合は訂正してください。

行末のすべての非オプション ( ./hello_world -c arg1 -b arg1 arg2 arg3) を収集できる例を見てきましたが、複数のオプションの最初の場合は収集できません。

Python のバージョンが異なるさまざまなプラットフォームでアプリを動作させたいので、argparser は調べていません。

4

7 に答える 7

18

はい、optparse で実行できます。

これは例です:

./test.py --categories=aaa --categories=bbb --categories ccc arg1 arg2 arg3

これは次を印刷します:

arguments: ['arg1', 'arg2', 'arg3']
options: {'categories': ['aaa', 'bbb', 'ccc']}

以下の完全な動作例:

#!/usr/bin/env python

import os, sys
from optparse import OptionParser
from optparse import Option, OptionValueError

VERSION = '0.9.4'

class MultipleOption(Option):
    ACTIONS = Option.ACTIONS + ("extend",)
    STORE_ACTIONS = Option.STORE_ACTIONS + ("extend",)
    TYPED_ACTIONS = Option.TYPED_ACTIONS + ("extend",)
    ALWAYS_TYPED_ACTIONS = Option.ALWAYS_TYPED_ACTIONS + ("extend",)

    def take_action(self, action, dest, opt, value, values, parser):
        if action == "extend":
            values.ensure_value(dest, []).append(value)
        else:
            Option.take_action(self, action, dest, opt, value, values, parser)


def main():
    PROG = os.path.basename(os.path.splitext(__file__)[0])
    long_commands = ('categories')
    short_commands = {'cat':'categories'}
    description = """Just a test"""
    parser = OptionParser(option_class=MultipleOption,
                          usage='usage: %prog [OPTIONS] COMMAND [BLOG_FILE]',
                          version='%s %s' % (PROG, VERSION),
                          description=description)
    parser.add_option('-c', '--categories', 
                      action="extend", type="string",
                      dest='categories', 
                      metavar='CATEGORIES', 
                      help='comma separated list of post categories')

    if len(sys.argv) == 1:
        parser.parse_args(['--help'])

    OPTIONS, args = parser.parse_args()
    print "arguments:", args
    print "options:", OPTIONS

if __name__ == '__main__':
    main()

詳細については、http://docs.python.org/library/optparse.html#adding-new-actionsを参照してください。

于 2012-05-01T21:44:52.337 に答える
8

パーティーに遅れて申し訳ありませんが、nargs フラグを使用して optparse でこれを解決しました。

parser.add_option('-c','--categories', dest='Categories', nargs=4 )

http://docs.python.org/2/library/optparse.html#optparse.Option.nargs

また、argparse (unutbu が推奨) は標準の python ディストリビューションの一部になりましたが、optparse は非推奨になったことにも注意してください。

于 2013-02-12T01:29:51.713 に答える
7

もう 1 つのオプションは、マウント コマンドのオプションのように、セパレータを定義してローカルで処理することです。

たとえば,、セパレータとして使用できる場合:

...
args, _ = getopt.getopt(sys.argv[1:],'b:')
for flag, arg in args:
  if flag=='-b': all_arguments = arg.split(',')
...

$ ./test -b opt1,opt2,opt3

宇宙も同じ!ただし、ユーザーはそれを適切に引用する必要があります。

$ ./test -b 'opt1 opt2 opt3'
于 2012-08-06T15:10:44.573 に答える
6

getoptもoptparseも、これをそのままではサポートしていません。さらに、デフォルト(GNU)モードでは、追加の引数は散在する引数として扱われます。つまり、処理の最後に残りの引数として使用できるようになります。

慣例では、同じ議論について繰り返し言及する必要があります。

./hello_world -c arg1 -c arg2 -c arg3 -b arg4 -b arg5 -b arg6 -b arg7

これはサポートされます。

どうしても指定した方法で動作させたい場合(つまり、-bと-cの両方を次の-引数または引数リストの最後まで拡張する)、optparseに基づいて何かを一緒にハックすることができます。OptionParserから継承し、_process_short_optsをオーバーライドします。それがオプションの1つである場合は、サブクラスで処理します。それ以外の場合は、基本クラスに転送します。

于 2010-11-05T20:11:36.857 に答える
5

Python2.7に付属しているnargsパラメータを使用してこれを行うことができ、ここからダウンロードできます。argparse

argparseこれは、に追加されていない改善の1つだと思いますoptparseoptparseですから、残念ながら、 or getopt(さらに古い)でこれを処理する良い方法はないと思います。

optparse/getop/argparse迅速で汚い解決策は、自分自身を放棄して解析することかもしれませんsys.argv

または、逆の方向に進むと、argparse(〜88K)のフリーズされたコピー(のような名前に変更argparse_static)をプログラムにパッケージ化して、次のようにインポートすることを検討できます。

try:
    import argparse
except ImportError:
    import argparse_static as argparse

そうすれば、プログラムargparseはインストールされている場合は使用し、インストールされ argparse_staticていない場合は使用します。argparse何よりも、標準になるほど多くのコードを書き直す必要はありません。

于 2010-11-05T20:10:45.700 に答える