跟大家講解下有關python命令行參數是什么,相信小伙伴們對這個話題應該也很關注吧,現在就為小伙伴們說說python命令行參數是什么,小編也收集到了有關python命令行參數是什么的相關資料,希望大家看到了會喜歡。

python命令行參數是什么?下面給大家具體介紹一下什么是命令行參數:
sys.argv
Python 中也可以所用 sys 的 sys.argv 來獲取命令行參數:
sys.argv 是命令行參數列表。
len(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']
相關推薦:《Python視頻教程》
示例:
import sysimport getopttry: 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----',valuepython test.py -i 127.0.0.1 -p 80 55 66python 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_groupcommon_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_groupparser.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.langmodule_id = options.module_idlocal_compile = options.local_compilemodule_path = options.local_compileargparse
類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 argparseparser = 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.keyhost = args.hostport = args.porttimeout = args.timeoutlimit = args.limitprogress-every = args.progress_everyverbose = args.verbose以上就是python命令行參數是什么的詳細內容,更多請關注php中文網其它相關文章!
來源:php中文網