日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
帶你了解3個(gè)Python命令行工具

用 Click、Docopt 和 Fire 庫寫你自己的命令行應(yīng)用。

創(chuàng)新互聯(lián)專注于企業(yè)成都營銷網(wǎng)站建設(shè)、網(wǎng)站重做改版、易縣網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為易縣等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

有時(shí)對(duì)于某項(xiàng)工作來說一個(gè)命令行工具就足以勝任。命令行工具是一種從你的 shell 或者終端之類的地方交互或運(yùn)行的程序。Git 和 Curl 就是兩個(gè)你也許已經(jīng)很熟悉的命令行工具。

當(dāng)你有一小段代碼需要在一行中執(zhí)行多次或者經(jīng)常性地被執(zhí)行,命令行工具就會(huì)很有用。Django 開發(fā)者執(zhí)行 ./manage.py runserver 命令來啟動(dòng)他們的網(wǎng)絡(luò)服務(wù)器;Docker 開發(fā)者執(zhí)行 docker-compose up 來啟動(dòng)他們的容器。你想要寫一個(gè)命令行工具的原因可能和你一開始想寫代碼的原因有很大不同。

對(duì)于這個(gè)月的 Python 專欄,我們有 3 個(gè)庫想介紹給希望為自己編寫命令行工具的 Python 使用者。

Click

Click 是我們***的用來開發(fā)命令行工具的 Python 包。其:

  • 有一個(gè)富含例子的出色文檔
  • 包含說明如何將命令行工具打包成一個(gè)更加易于執(zhí)行的 Python 應(yīng)用程序
  • 自動(dòng)生成實(shí)用的幫助文本
  • 使你能夠疊加使用可選和必要參數(shù),甚至是 多個(gè)命令
  • 有一個(gè) Django 版本( django-click )用來編寫管理命令

Click 使用 @click.command() 去聲明一個(gè)函數(shù)作為命令,同時(shí)可以指定必要和可選參數(shù)。

 
 
 
 
  1. # hello.py
  2. import click
  3.  
  4. @click.command()
  5. @click.option('--name', default='', help='Your name')
  6. def say_hello(name):
  7. click.echo("Hello {}!".format(name))
  8.  
  9. if __name__ == '__main__':
  10. say_hello()

@click.option() 修飾器聲明了一個(gè) 可選參數(shù) ,而 @click.argument() 修飾器聲明了一個(gè) 必要參數(shù)。你可以通過疊加修飾器來組合可選和必要參數(shù)。echo() 方法將結(jié)果打印到控制臺(tái)。

 
 
 
 
  1. $ python hello.py --name='Lacey'
  2. Hello Lacey!

Docopt

Docopt 是一個(gè)命令行工具的解析器,類似于命令行工具的 Markdown。如果你喜歡流暢地編寫應(yīng)用文檔,在本文推薦的庫中 Docopt 有著***的格式化幫助文本。它不是我們***的命令行工具開發(fā)包的原因是它的文檔猶如把人扔進(jìn)深淵,使你開始使用時(shí)會(huì)有一些小困難。然而,它仍是一個(gè)輕量級(jí)的、廣受歡迎的庫,特別是當(dāng)一個(gè)漂亮的說明文檔對(duì)你來說很重要的時(shí)候。

Docopt 對(duì)于如何格式化文章開頭的 docstring 是很特別的。在工具名稱后面的 docsring 中,頂部元素必須是 Usage: 并且需要列出你希望命令被調(diào)用的方式(比如:自身調(diào)用,使用參數(shù)等等)。Usage: 需要包含 helpversion 參數(shù)。

docstring 中的第二個(gè)元素是 Options:,對(duì)于在 Usages: 中提及的可選項(xiàng)和參數(shù),它應(yīng)當(dāng)提供更多的信息。你的 docstring 的內(nèi)容變成了你幫助文本的內(nèi)容。

 
 
 
 
  1. """HELLO CLI
  2.  
  3. Usage:
  4. hello.py
  5. hello.py
  6. hello.py -h|--help
  7. hello.py -v|--version
  8.  
  9. Options:
  10. Optional name argument.
  11. -h --help Show this screen.
  12. -v --version Show version.
  13. """
  14.  
  15. from docopt import docopt
  16.  
  17. def say_hello(name):
  18. return("Hello {}!".format(name))
  19.  
  20.  
  21. if __name__ == '__main__':
  22. arguments = docopt(__doc__, version='DEMO 1.0')
  23. if arguments['']:
  24. print(say_hello(arguments['']))
  25. else:
  26. print(arguments)

在最基本的層面,Docopt 被設(shè)計(jì)用來返回你的參數(shù)鍵值對(duì)。如果我不指定上述的 name 調(diào)用上面的命令,我會(huì)得到一個(gè)字典的返回值:

 
 
 
 
  1. $ python hello.py
  2. {'--help': False,
  3.  '--version': False,
  4.  '': None}

這里可看到我沒有輸入 helpversion 標(biāo)記并且 name 參數(shù)是 None。

但是如果我?guī)е粋€(gè) name 參數(shù)調(diào)用,say_hello 函數(shù)就會(huì)執(zhí)行了。

 
 
 
 
  1. $ python hello.py Jeff
  2. Hello Jeff!

Docopt 允許同時(shí)指定必要和可選參數(shù),且各自有著不同的語法約定。必要參數(shù)需要在 ALLCAPS 中展示,而可選參數(shù)需要單雙橫杠顯示,就像 --like。更多內(nèi)容可以閱讀 Docopt 有關(guān) patterns 的文檔。

Fire

Fire 是谷歌的一個(gè)命令行工具開發(fā)庫。尤其令人喜歡的是當(dāng)你的命令需要更多復(fù)雜參數(shù)或者處理 Python 對(duì)象時(shí),它會(huì)聰明地嘗試解析你的參數(shù)類型。

Fire 的 文檔 包括了海量的樣例,但是我希望這些文檔能被更好地組織。Fire 能夠處理 同一個(gè)文件中的多條命令、使用 對(duì)象 的方法作為命令和 分組 命令。

它的弱點(diǎn)在于輸出到控制臺(tái)的文檔。命令行中的 docstring 不會(huì)出現(xiàn)在幫助文本中,并且?guī)椭谋疽膊灰欢?biāo)識(shí)出參數(shù)。

 
 
 
 
  1. import fire
  2.  
  3.  
  4. def say_hello(name=''):
  5. return 'Hello {}!'.format(name)
  6.  
  7.  
  8. if __name__ == '__main__':
  9. fire.Fire()

參數(shù)是必要還是可選取決于你是否在函數(shù)或者方法定義中為其指定了一個(gè)默認(rèn)值。要調(diào)用命令,你必須指定文件名和函數(shù)名,比較類似 Click 的語法:

 
 
 
 
  1. $ python hello.py say_hello Rikki
  2. Hello Rikki!

你還可以像標(biāo)記一樣傳參,比如 --name=Rikki。

額外贈(zèng)送:打包!

Click 包含了使用 setuptools 打包 命令行工具的使用說明(強(qiáng)烈推薦按照說明操作)。

要打包我們***個(gè)例子中的命令行工具,將以下內(nèi)容加到你的 setup.py 文件里:

 
 
 
 
  1. from setuptools import setup
  2.  
  3. setup(
  4. name='hello',
  5. version='0.1',
  6. py_modules=['hello'],
  7. install_requires=[
  8. 'Click',
  9. ],
  10. entry_points='''
  11. [console_scripts]
  12. hello=hello:say_hello
  13. ''',
  14. )

任何你看見 hello 的地方,使用你自己的模塊名稱替換掉,但是要記得忽略 .py 后綴名。將 say_hello 替換成你的函數(shù)名稱。

然后,執(zhí)行 pip install --editable 來使你的命令在命令行中可用。

現(xiàn)在你可以調(diào)用你的命令,就像這樣:

 
 
 
 
  1. $ hello --name='Jeff'
  2. Hello Jeff!

通過打包你的命令,你可以省掉在控制臺(tái)鍵入 python hello.py --name='Jeff' 這種額外的步驟以減少鍵盤敲擊。這些指令也很可能可在我們提到的其他庫中使用。


名稱欄目:帶你了解3個(gè)Python命令行工具
鏈接分享:http://www.dlmjj.cn/article/djccdjh.html