python命令行參數解析

sys.argv

sys.argv[0]是腳本文件的名字,如:test.py

sys.argv[1:]是以空格分割的參數列表

getopt

函數原型:

getopt(args, shortopts, longopts = [])

參數:
args:需要解析的參數,一般是sys.argv[1:]
shortopts:短格式 (-),有冒號:表示參數后面需要參數值,沒有冒號表示后面無需參數值
longopts:長格式(--) ,有等號表示參數后面需要參數值,沒有等號表示后面無需參數值
返回值:
options是個包含元祖的列表,每個元祖是分析出來的格式信息,比如 [('-i','127.0.0.1'),('-p','80')] ;
args 是個列表,包含那些沒有‘-’或‘--’的參數,比如:['55','66']

示例:

import sys
import getopt
try:
    options,args = getopt.getopt(sys.argv[1:],"hp:i:", ["help","ip=","port="])
except getopt.GetoptError:
    sys.exit()
for name,value in options:
    if name in ("-h","--help"):
        usage()
    if name in ("-i","--ip"):
        print 'ip is----',value
    if name in ("-p","--port"):
        print 'port is----',value

python test.py -i 127.0.0.1 -p 80 55 66
python test.py --ip=127.0.0.1 --port=80 55 66

“hp:i:”
短格式 --- h 后面沒有冒號:表示后面不帶參數,p:和 i:后面有冒號表示后面需要參數
["help","ip=","port="]
長格式 --- help后面沒有等號=,表示后面不帶參數,其他三個有=,表示后面需要參數
注意:定義命令行參數時,要先定義帶'-'選項的參數,再定義沒有‘-’的參數

optparse

類OptionParser

class optparse.OptionParser(usage=None, 
                 option_list=None,
                 option_class=Option,
                 version=None,
                 conflict_handler="error",
                 description=None,
                 formatter=None,
                 add_help_option=True,
                 prog=None,
                 epilog=None)
                 

參數:
usage:程序的使用說明,其中"%prog"會替換為文件名(或者prog屬性,若指定了prog屬性值),"[options]"會替換為各個參數的使用說明
version:版本號

函數add_option()

add_option(short, long, action, type, dest, default, help)

參數:
short option string: 為第一個參數,表示option的縮寫,例如-f;
long option string: 為第二個參數,表示option的全拼,例如--file;
action=: 表示對此option的處理方式,默認值為store,表示存儲option的值到解析后的options對象的成員中。

action還可以有其他的值:對于bool值,使用store_true來默認存儲true,使用store_false來默認存儲false,store_const用來存儲const設置的值到此option,append表示增加option的參數到list中,此時此option是一個list,可能包含多個值,count表示對counter增加一,callback表示調用指定的函數。所有的action值如下:
store + store_true + store_false + store_const + append + count + callback

type=:表示此option的值的類型,默認為string,可以指定為string, int, choice, float and complex;
dest=:表示此option在經過optionparser解析后的options對象中成員的名字,默認使用long option string;
help=:表示這個參數的使用說明;
default=:表示比option的默認值;
metavar=:表示顯示到help中option的默認值;
const=:當action為store_const的時候,需要設置此值;
choices=:當設置type為choices時,需要設置此值;

函數parse_args

(options, args) = parser.parse_args()

返回值:
options為是一個directory,它的內容為“參數/值 ”的鍵值對。
args是一個list,它的內容是所有參數除去options后,剩余的輸入內容。

簡單用法:

from optparse import OptionParser  
  
parser = OptionParser(usage="usage:%prog [options] arg1 arg2")  
parser.add_option("-t", "--timeout",  
                action = "store",  
                type = 'int',  
                dest = "timeout",  
                default = None,  
                help="Specify annalysis execution time limit"  
                )  
parser.add_option("-u", "--url",  
                action = "store_true",  
                dest = "url",  
                default = False,  
                help = "Specify if the target is an URL"  
                )
(options, args) = parser.parse_args() 
if options.url:  
    print(args[0]) 

復雜用法:參數分組

parser = optparse.OptionParser(version="%prog " + config.version)
# common_group
common_group = optparse.OptionGroup(
    parser, "Common Options",
    "Common options for code-coverage.")
parser.add_option_group(common_group)
common_group.add_option(
    "-l", "--lang", dest="lang", type="string", default="cpp",
    help="module language.", metavar="STRING")
common_group.add_option(
    "--module_id", dest="module_id", type="int", default=None,
    help="module id.", metavar="INT")
cpp_group = optparse.OptionGroup(
    parser, "C/C++ Options",
    "Special options for C/C++.")
# cpp_group
parser.add_option_group(cpp_group)
cpp_group.add_option(
    "--local-compile", action="store_true", dest="local_compile",
    help="compile locally, do not use compile cluster.")
cpp_group.add_option(
    "--module_path", dest="module_path", type="string", default=None,
    help="module path, like app/ecom/nova/se/se-as.", metavar="STRING")
    
options, arguments = parser.parse_args()
lang = options.lang
module_id = options.module_id
local_compile = options.local_compile
module_path = options.local_compile

argparse

類ArgumentParser

class argparse.ArgumentParser(prog=None, 
                usage=None, 
                description=None, 
                epilog=None, 
                parents=[], 
                formatter_class=argparse.HelpFormatter,
                prefix_chars='-', 
                fromfile_prefix_chars=None, 
                argument_default=None, 
                conflict_handler='error', 
                add_help=True)

參數:
prog:程序的名字(默認:sys.argv[0])
usage:描述程序用法的字符串(默認:從解析器的參數生成)
description:參數幫助信息之前的文本(默認:空)
epilog:參數幫助信息之后的文本(默認:空)
parents:ArgumentParser 對象的一個列表,這些對象的參數應該包括進去
formatter_class:定制化幫助信息的類
prefix_chars:可選參數的前綴字符集(默認:‘-‘)
fromfile_prefix_chars:額外的參數應該讀取的文件的前綴字符集(默認:None)
argument_default:參數的全局默認值(默認:None)
conflict_handler:解決沖突的可選參數的策略(通常沒有必要)
add_help:給解析器添加-h/–help 選項(默認:True)

函數add_argument()

add_argument(name or flags...[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])

參數:
name or flags:選項字符串的名字或者列表,例如foo 或者-f, --foo。
action:在命令行遇到該參數時采取的基本動作類型。
nargs:應該讀取的命令行參數數目。
const:某些action和nargs選項要求的常數值。
default:如果命令行中沒有出現該參數時的默認值。
type:命令行參數應該被轉換成的類型。
choices:參數可允許的值的一個容器。
required:該命令行選項是否可以省略(只針對可選參數)。
help:參數的簡短描述。
metavar:參數在幫助信息中的名字。
dest:給parse_args()返回的對象要添加的屬性名稱。

簡單用法:

import argparse
parser = argparse.ArgumentParser(description="progrom description")
parser.add_argument('key', help="Redis key where items are stored")
parser.add_argument('--host')
arser.add_argument('--port')
parser.add_argument('--timeout', type=int, default=5)
parser.add_argument('--limit', type=int, default=0)
parser.add_argument('--progress_every', type=int, default=100)
parser.add_argument('-v', '--verbose', action='store_true')
args = parser.parse_args()

key = args.key
host = args.host
port = args.port
timeout = args.timeout
limit = args.limit
progress-every = args.progress_every
verbose = args.verbose
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,182評論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 99,489評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,290評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,776評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,510評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,866評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,860評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,036評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 49,585評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,331評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,536評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,058評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,754評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,154評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,469評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,273評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,505評論 2 379

推薦閱讀更多精彩內容