argparse:用于使用python構建工具時,讓可執(zhí)行python文件可以獲取外部參數(shù),形如:
$ command.py [-h|--help]
$ command.py [位置參數(shù)] [-可選參數(shù)前綴 [可選參數(shù)]]
ArgumentParser()類,包括:幫助參數(shù)、位置參數(shù)、可選參數(shù)。其中:
- 幫助參數(shù)無需指定,可以可以直接調(diào)用,該命令會顯示出你定義過的所有參數(shù)的輸入要求和幫助信息(
help="xxx"); - 位置參數(shù)按順序儲存,調(diào)用時使用位置參數(shù)變量名進行調(diào)用;
- 可選參數(shù)可以用于:從外部接收值;轉(zhuǎn)換選項狀態(tài)(
action="store_true");使用短命令(add_argument('-l', '--long', ...));數(shù)該參數(shù)出現(xiàn)了多少次(action="count") - 可選參數(shù)和位置參數(shù)順序交叉無關緊要,只需要位置參數(shù)們的相對位置正確即可;
- 接受值的參數(shù)如果需要限定合法范圍,可以使用
choices=[x, y, z, ...]; - 接受值的參數(shù)如果需要指定缺省值(默認是
None),可以使用default=...; - 使用
add_mutually_exclusive_group()為參數(shù)添加(一組)互斥的選項,即該組中的可選參數(shù)不能同時出現(xiàn),否則會報錯。
import argparse
parser = argparse.ArgumentParser(description="calculate X to the power of Y")
# group = parser.add_mutually_exclusive_group()
# group.add_argument("-v", "--verbose", action="store_true")
# group.add_argument("-q", "--quiet", action="store_true")
# -v --> args.quiet = False
parser.add_argument("x", type=int, help="the base")
parser.add_argument("y", type=int, help="the exponent")
# parser.add_argument("-v", "--verbose", action="store_true", help="increase output verbosity")
# -v/--verbose --> args.verbosity = True
# parser.add_argument("-v", "--verbose", action="count", default=0, help="increase output verbosity")
# -v/--verbose --> args.verbosity = 1
# -vv/--verbose --verbose --> args.verbose = 2
# ...
parser.add_argument("-v", "--verbosity", type=int, choices=[0, 1, 2], help="increase output verbosity")
args = parser.parse_args()
answer = args.x**args.y
if args.verbosity == 2:
print("Running '{}'".format(__file__))
if args.verbosity == 1:
print("{}^{} == ".format(args.x, args.y), end="")
print(answer)