TL; DR
使用するnargs
オプションまたは'append'
の設定action
(ユーザーインターフェイスが動作するようにする方法に応じて)オプションを選択します。
ナルグス
parser.add_argument('-l','--list', nargs='+', help='<Required> Set flag', required=True)
# Use like:
# python arg.py -l 1234 2345 3456 4567
nargs='+'
1つ以上の引数をnargs='*'
取り、0以上を取ります。
追加する
parser.add_argument('-l','--list', action='append', help='<Required> Set flag', required=True)
# Use like:
# python arg.py -l 1234 -l 2345 -l 3456 -l 4567
と append
、あなたのリストを構築するためのオプションを複数回提供しています。
使用しないでくださいtype=list
!!! -おそらくあなたが使用したいと思う何も状況はありませんtype=list
でargparse
。ずっと。
これを行おうとするさまざまな方法のいくつかと、最終結果をさらに詳しく見てみましょう。
import argparse
parser = argparse.ArgumentParser()
# By default it will fail with multiple arguments.
parser.add_argument('--default')
# Telling the type to be a list will also fail for multiple arguments,
# but give incorrect results for a single argument.
parser.add_argument('--list-type', type=list)
# This will allow you to provide multiple arguments, but you will get
# a list of lists which is not desired.
parser.add_argument('--list-type-nargs', type=list, nargs='+')
# This is the correct way to handle accepting multiple arguments.
# '+' == 1 or more.
# '*' == 0 or more.
# '?' == 0 or 1.
# An int is an explicit number of arguments to accept.
parser.add_argument('--nargs', nargs='+')
# To make the input integers
parser.add_argument('--nargs-int-type', nargs='+', type=int)
# An alternate way to accept multiple inputs, but you must
# provide the flag once per input. Of course, you can use
# type=int here if you want.
parser.add_argument('--append-action', action='append')
# To show the results of the given option to screen.
for _, value in parser.parse_args()._get_kwargs():
if value is not None:
print(value)
期待できる出力は次のとおりです。
$ python arg.py --default 1234 2345 3456 4567
...
arg.py: error: unrecognized arguments: 2345 3456 4567
$ python arg.py --list-type 1234 2345 3456 4567
...
arg.py: error: unrecognized arguments: 2345 3456 4567
$ # Quotes won't help here...
$ python arg.py --list-type "1234 2345 3456 4567"
['1', '2', '3', '4', ' ', '2', '3', '4', '5', ' ', '3', '4', '5', '6', ' ', '4', '5', '6', '7']
$ python arg.py --list-type-nargs 1234 2345 3456 4567
[['1', '2', '3', '4'], ['2', '3', '4', '5'], ['3', '4', '5', '6'], ['4', '5', '6', '7']]
$ python arg.py --nargs 1234 2345 3456 4567
['1234', '2345', '3456', '4567']
$ python arg.py --nargs-int-type 1234 2345 3456 4567
[1234, 2345, 3456, 4567]
$ # Negative numbers are handled perfectly fine out of the box.
$ python arg.py --nargs-int-type -1234 2345 -3456 4567
[-1234, 2345, -3456, 4567]
$ python arg.py --append-action 1234 --append-action 2345 --append-action 3456 --append-action 4567
['1234', '2345', '3456', '4567']
要点:
nargs
またはを使用action='append'
nargs
ユーザーの観点からはより簡単ですが、位置引数argparse
がある場合、何が位置引数であり、何に属しているのかを判断できないため、位置引数がある場合は直感的ではない可能性がありますnargs
。位置引数がある場合action='append'
は、最終的にはより良い選択になる可能性があります。
- 上記の場合にのみ真で
nargs
与えられている'*'
、'+'
または'?'
。整数などを指定した場合(など4
)、オプションに予想される値の数が正確にわかるnargs
ため、オプションと位置引数を混在させることは問題ありませんargparse
。
- コマンドラインで引用符を使用しないでください1
- 使わない
type=list
リストのリストを返す、
- これは、フードの下での
argparse
値を使用して、選択した引数を指定された各個人type
に強制するために発生しますtype
、すべての引数の集計ではなく、します。
type=int
(または何でも)を使用して、int(または何でも)のリストを取得できます。
1:私は一般的には意味しません。.引用符を使用してリストを渡すことargparse
は、あなたが望むものではないことを意味します。