python argparse模塊傳參用法實例

前言

argsparse是python的命令行解析的標準模塊,內置於python,不需要安裝。這個庫可以讓我們直接在命令行中就可以向程序中傳入參數並讓程序運行。

港真的,今天是我第一次學習argsparse。因為用不到,自然也就沒有學習的動力。但是現在電腦有點卡,每次打開pycharm太卡瞭,逼得我不得不開始使用命令行來測試代碼。

傳入一個參數

我們先在桌面新建“arg學習”的文件夾,在該文件夾中新建demo.py文件,來看一個最簡單的argsparse庫的使用的例子。

import argparse
parser = argparse.ArgumentParser(description='命令行中傳入一個數字')
#type是要傳入的參數的數據類型  help是該參數的提示信息
parser.add_argument('integers', type=str, help='傳入的數字')
args = parser.parse_args()
#獲得傳入的參數
print(args)

在這個代碼中,我們在命令行傳入一個數字。使用方法是打開命令行,先將工作目錄cd到arg學習

cd desktop/arg學習

然後再命令行中輸入python demo.py -h或者python demo.py –help, 這裡我輸入的是

python demo.py -h

在命令行中看到demo.py的運行結果如下

usage: demo.py [-h] integers
命令行中傳入數字
positional arguments:
  integers    傳入的數字
optional arguments:
  -h, --help  show this help message and exit

現在我們在命令行中給demo.py 傳入一個參數5,

python demo.py 5

運行,得到的運行結果是

Namespace(integers='5')

操作args字典

其實得到的這個結果Namespace(integers='5')是一種類似於python字典的數據類型。

我們可以使用 arg.參數名來提取這個參數

import argparse
parser = argparse.ArgumentParser(description='命令行中傳入一個數字')
#type是要傳入的參數的數據類型  help是該參數的提示信息
parser.add_argument('integers', type=str, help='傳入的數字')
args = parser.parse_args()
#獲得integers參數
print(args.integers)

在命令行中運行 python demo.py 5 , 運行結果為

5

傳入多個參數

現在在命令行中給demo.py 傳入多個參數,例如傳入1,2,3,4四個數字

python demo.py 1 2 3 4

運行報錯

usage: demo.py [-h] integers 
demo.py: error: unrecognized arguments: 2 3 4

不能識別2 3 4,看源代碼我們知道integers這個參數是位置參數,說明第一個數1是能識別。這裡我們需要重新更改demo.py代碼

import argparse
parser = argparse.ArgumentParser(description='命令行中傳入一個數字')
parser.add_argument('integers', type=str, nargs='+',help='傳入的數字')
args = parser.parse_args()
print(args.integers)

nargs是用來說明傳入的參數個數,'+' 表示傳入至少一個參數。這時候再重新在命令行中運行python demo.py 1 2 3 4得到

['1', '2', '3', '4']

改變數據類型

add_argument中有type參數可以設置傳入參數的數據類型。我們看到代碼中有type這個關鍵詞,該關鍵詞可以傳入list, str, tuple, set, dict等。例如我們把上面的type=str,改成type=int,這時候我們就可以進行四則運算。

import argparse
parser = argparse.ArgumentParser(description='命令行中傳入一個數字')
parser.add_argument('integers', type=int, nargs='+',help='傳入的數字')
args = parser.parse_args()
#對傳入的數據進行加總
print(sum(args.integers)

在命令行中輸入 python demo.py 1 2 3 4, 運行結果為

10

位置參數

在命令行中傳入參數時候,傳入的參數的先後順序不同,運行結果往往會不同,這是因為采用瞭位置參數,例如

import argparse
parser = argparse.ArgumentParser(description='姓名')
parser.add_argument('param1', type=str,help='姓')
parser.add_argument('param2', type=str,help='名')
args = parser.parse_args()
#打印姓名
print(args.param1+args.param2)

在命令行中分別輸入python demo.py 張 三和python demo.py 三 張,得到的 運行結果分別為

張三

三張

如果我們將代碼

parser.add_argument('param1', type=str,help='姓')

parser.add_argument('param2', type=str,help='名')互

換位置,即第4行和第五行代碼,再重新運行

python demo.py 張 三 和 python demo.py 三 張,得到的 運行結果分別為

三張

張三

可選參數

為瞭在命令行中避免上述位置參數的bug(容易忘瞭順序),可以使用可選參數,這個有點像關鍵詞傳參,但是需要在關鍵詞前面加–,例如

import argparse
parser = argparse.ArgumentParser(description='姓名')
parser.add_argument('--family', type=str,help='姓')
parser.add_argument('--name', type=str,help='名')
args = parser.parse_args()
#打印姓名
print(args.family+args.name)

在命令行中輸入

python demo.py --family=張 --name=三

運行結果

張三

可選參數雖然寫法比較繁瑣,但是增加瞭命令行中的可讀性,不容易因為參數傳入順序導致數據錯亂。

默認值

add_argument中有一個default參數。有的時候需要對某個參數設置默認值,即如果命令行中沒有傳入該參數的值,程序使用默認值。如果命令行傳入該參數,則程序使用傳入的值。具體請看下面的例子

import argparse
parser = argparse.ArgumentParser(description='姓名')
parser.add_argument('--family', type=str, default='張',help='姓')
parser.add_argument('--name', type=str, default='三', help='名')
args = parser.parse_args()
#打印姓名
print(args.family+args.name)

在命令行中分別輸入 python demo.py 、 python demo.py –family=李

運行結果分別為

張三

李三

必需參數

add_argument有一個required參數可以設置該參數是否必需。

import argparse
parser = argparse.ArgumentParser(description='姓名')
parser.add_argument('--family', type=str, help='姓')
parser.add_argument('--name', type=str, required=True, default='', help='名')
args = parser.parse_args()
#打印姓名
print(args.family+args.name)

在命令行中輸入 python demo.py –family=張,運行結果

usage: demo.py [-h] [--family FAMILY] --name NAME
demo.py: error: the following arguments are required: --name

因為可選參數name的required=True,所以必須要傳入。如果我們將其更改為False,程序運行結果

以上就是python argparse模塊傳參用法實例詳解的詳細內容,更多關於python argparse模塊傳參的資料請關註WalkonNet其它相關文章!

推薦閱讀: