首頁 > 後端開發 > Python教學 > python命令列參數是什麼

python命令列參數是什麼

爱喝马黛茶的安东尼
發布: 2019-06-25 09:44:12
原創
6268 人瀏覽過

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 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_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.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
登入後複製

以上是python命令列參數是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板