溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python命令行解析模塊的示例分析

發(fā)布時(shí)間:2021-08-03 11:36:51 來(lái)源:億速云 閱讀:115 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下Python命令行解析模塊的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

getopt模塊

這個(gè)模塊可以幫助腳本解析命令行參數(shù),一般是sys.argv[1:]。它遵循著Unix的getopt()函數(shù)相同的約定(用-/--指定命令參數(shù))。這個(gè)模塊提供兩個(gè)函數(shù)(getopt.getopt()/getopt.gnu_getopt())和一個(gè)參數(shù)異常(getopt.GetoptError)。

這里重點(diǎn)介紹getopt.getopt()這個(gè)函數(shù)。

函數(shù)原型:getopt.getopt(args, options[, long_options])

這個(gè)函數(shù)有三個(gè)參數(shù):

  • args:腳本要解析的命令行參數(shù);

  • options:命令行短選項(xiàng),如果指定的短選項(xiàng)后面需要跟參數(shù)的話,要在相應(yīng)短選項(xiàng)后面加“:”,如e:;

  • long_options:命令行長(zhǎng)選項(xiàng),這個(gè)參數(shù)是可選的。如果指定的長(zhǎng)選項(xiàng)后面要跟參數(shù)的話,要在相應(yīng)長(zhǎng)選項(xiàng)后面加上“=”,如conding=;

當(dāng)給定的命令行參數(shù)解析不了的話,就會(huì)拋出GetoptError異常。

函數(shù)的返回值包含兩個(gè)元素:

  • 第一個(gè)元素是一個(gè)(option,value)元組對(duì)。Option是解析的參數(shù),value是對(duì)應(yīng)參數(shù)的值;

  • 第二個(gè)元素是腳本不需要執(zhí)行的參數(shù)列表。也就是這些參數(shù)是多余的;

下面看幾個(gè)Demo:

短選項(xiàng):

>>> importgetopt
>>> args='-a -b -cfoo -d bar a1 a2'.split()
>>> args
['-a', '-b', '-cfoo', '-d', 'bar', 'a1','a2']
>>> optlist, args= getopt.getopt(args,'abc:d:')
>>> optlist
[('-a', ''), ('-b', ''), ('-c', 'foo'),('-d', 'bar')]
>>> args
['a1', 'a2']

長(zhǎng)選項(xiàng):

>>> s='--condition=foo --testing --output-file abc.def -x a1 a2'
>>> args= s.split()
>>> args
['--condition=foo', '--testing','--output-file', 'abc.def', '-x', 'a1', 'a2']
>>> optlist, args= getopt.getopt(args,'x', [
...   'condition=','output-file=','testing'])
>>> optlist
[('--condition', 'foo'), ('--testing', ''),('--output-file', 'abc.def'), ('-x', '')]
>>> args
['a1', 'a2']

在腳本當(dāng)中經(jīng)典的應(yīng)用實(shí)例:

importgetopt,sys
 
defmain():
  try:
    opts, args = getopt.getopt(sys.argv[1:],"ho:v", ["help","output="])
  except getopt.GetoptErroras err:
    # print help information and exit:
    printstr(err) # will print something like "option -a not recognized"
    usage()
    sys.exit(2)
  output =None
  verbose =False
  for o, a in opts:
    if o =="-v":
      verbose =True
    elif o in ("-h","--help"):
      usage()
      sys.exit()
    elif o in ("-o","--output"):
      output = a
    else:
      assertFalse,"unhandled option"
  # ...
 
if __name__ =="__main__":
  main()

argparse模塊

argparse模塊使得編寫用戶友好的命令行接口非常容易。程序只需定義好它要求的參數(shù),然后argparse將負(fù)責(zé)如何從sys.argv中解析出這些參數(shù)。argparse模塊還會(huì)自動(dòng)生成幫助和使用信息并且當(dāng)用戶賦給程序非法的參數(shù)時(shí)產(chǎn)生錯(cuò)誤信息。
使用argparse模塊一般需要三個(gè)步驟:

1. 創(chuàng)建一個(gè)解析器

使用argparse的第一步是創(chuàng)建一個(gè)ArgumentParser對(duì)象:

>>> parser= argparse.ArgumentParser()

ArgumentParser對(duì)象會(huì)保存把命令行解析成Python數(shù)據(jù)類型所需要的所有信息。

2. 添加參數(shù)

通過(guò)調(diào)用add_argument()方法向ArgumentParser添加程序的參數(shù)信息。通常情況下,這些信息告訴ArgumentParser如何接收命令行上的字符串并將它們轉(zhuǎn)換成對(duì)象。這些信息被保存下來(lái)并在調(diào)用parse_args()時(shí)用到。例如:

>>> parser.add_argument('--name', help='username')
>>> parser.add_argument('--pass', help='password ')

接下來(lái),調(diào)用parse_args()返回的對(duì)象將帶有兩個(gè)屬性,name和pass。分別保存著用戶名與密碼。

3. 解析參數(shù)

ArgumentParser通過(guò)parse_args()方法解析參數(shù)。它將檢查命令行,把每個(gè)參數(shù)轉(zhuǎn)換成恰當(dāng)?shù)念愋筒⒉扇∏‘?dāng)?shù)膭?dòng)作。在大部分情況下,這意味著將從命令行中解析出來(lái)的屬性建立一個(gè)簡(jiǎn)單的 Namespace對(duì)象。

>>> argments = parser.parse_args(['--name','li','--pass','si'])

在腳本中,parse_args() 調(diào)用一般不帶參數(shù),ArgumentParser 將根據(jù)sys.argv自動(dòng)確定命令行參數(shù)。

ArgumentParser 對(duì)象

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)

創(chuàng)建一個(gè)新的argmentParserr對(duì)象。所有的參數(shù)應(yīng)該以關(guān)鍵字參數(shù)傳遞。下面有對(duì)每個(gè)參數(shù)各自詳細(xì)的描述,但是簡(jiǎn)短地講它們是:

  • prog - 程序的名字(默認(rèn):sys.argv[0])

  • useage - 描述程序用法的字符串(默認(rèn):從解析器的參數(shù)生成)

  • description - 參數(shù)幫助信息之前的文本(默認(rèn):空)

  • epilog- 參數(shù)幫助信息之后的文本(默認(rèn):空)

  • parents - ArgmentParser 對(duì)象的一個(gè)列表,這些對(duì)象的參數(shù)應(yīng)該包括進(jìn)去

  • ormatter_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)

add_argument() 方法

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

定義應(yīng)該如何解析一個(gè)命令行參數(shù)。下面每個(gè)參數(shù)有它們自己詳細(xì)的描述,簡(jiǎn)單地講它們是:

  • 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ì)象要添加的屬性名稱。

以上是“Python命令行解析模塊的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI