小抄 | python常用原生包之`argparse`

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)

argparse的更多方法和例子

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容