真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

python命令行參數(shù)的案例分析-創(chuàng)新互聯(lián)

了解python命令行參數(shù)的案例分析?這個(gè)問(wèn)題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見(jiàn)到的。希望通過(guò)這個(gè)問(wèn)題能讓你收獲頗深。下面是小編給大家?guī)?lái)的參考內(nèi)容,讓我們一起來(lái)看看吧!

創(chuàng)新互聯(lián)是一家專業(yè)提供吉木乃企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、H5場(chǎng)景定制、小程序制作等業(yè)務(wù)。10年已為吉木乃眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。

python命令行參數(shù)是什么?下面給大家具體介紹一下什么是命令行參數(shù):

sys.argv

Python 中也可以所用 sys 的 sys.argv 來(lái)獲取命令行參數(shù):

sys.argv 是命令行參數(shù)列表。

len(sys.argv) 是命令行參數(shù)個(gè)數(shù)。

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

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

getopt

函數(shù)原型:

getopt(args, shortopts, longopts = [])

參數(shù):
args:需要解析的參數(shù),一般是sys.argv[1:]
shortopts:短格式 (-),有冒號(hào):表示參數(shù)后面需要參數(shù)值,沒(méi)有冒號(hào)表示后面無(wú)需參數(shù)值
longopts:長(zhǎng)格式(--) ,有等號(hào)表示參數(shù)后面需要參數(shù)值,沒(méi)有等號(hào)表示后面無(wú)需參數(shù)值
返回值:
options是個(gè)包含元祖的列表,每個(gè)元祖是分析出來(lái)的格式信息,比如 [('-i','127.0.0.1'),('-p','80')] ;
args 是個(gè)列表,包含那些沒(méi)有‘-’或‘--’的參數(shù),比如:['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 后面沒(méi)有冒號(hào):表示后面不帶參數(shù),p:和 i:后面有冒號(hào)表示后面需要參數(shù)
["help","ip=","port="]  
長(zhǎng)格式 --- help后面沒(méi)有等號(hào)=,表示后面不帶參數(shù),其他三個(gè)有=,表示后面需要參數(shù)
注意:定義命令行參數(shù)時(shí),要先定義帶'-'選項(xiàng)的參數(shù),再定義沒(méi)有‘-’的參數(shù)

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)

參數(shù):

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

函數(shù)add_option()

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

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

action還可以有其他的值:對(duì)于bool值,使用store_true來(lái)默認(rèn)存儲(chǔ)true,使用store_false來(lái)默認(rèn)存儲(chǔ)false,store_const用來(lái)存儲(chǔ)const設(shè)置的值到此option,append表示增加option的參數(shù)到list中,此時(shí)此option是一個(gè)list,可能包含多個(gè)值,count表示對(duì)counter增加一,callback表示調(diào)用指定的函數(shù)。所有的action值如下:
store + store_true + store_false + store_const + append + count + callback

type=:表示此option的值的類型,默認(rèn)為string,可以指定為string, int, choice, float and complex;
dest=:表示此option在經(jīng)過(guò)optionparser解析后的options對(duì)象中成員的名字,默認(rèn)使用long option string;
help=:表示這個(gè)參數(shù)的使用說(shuō)明;
default=:表示比option的默認(rèn)值;
metavar=:表示顯示到help中option的默認(rèn)值;
const=:當(dāng)action為store_const的時(shí)候,需要設(shè)置此值;
choices=:當(dāng)設(shè)置type為choices時(shí),需要設(shè)置此值;

函數(shù)parse_args

(options, args) = parser.parse_args()

返回值:
options為是一個(gè)directory,它的內(nèi)容為“參數(shù)/值 ”的鍵值對(duì)。
args是一個(gè)list,它的內(nèi)容是所有參數(shù)除去options后,剩余的輸入內(nèi)容。

簡(jiǎn)單用法:

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])

復(fù)雜用法:參數(shù)分組

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)

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

函數(shù)add_argument()

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

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

簡(jiǎn)單用法:

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

感謝各位的閱讀!看完上述內(nèi)容,你們對(duì)python命令行參數(shù)的案例分析大概了解了嗎?希望文章內(nèi)容對(duì)大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


本文題目:python命令行參數(shù)的案例分析-創(chuàng)新互聯(lián)
網(wǎng)站地址:http://weahome.cn/article/ccesoc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部