成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

帶你了解3個Python命令行工具

開發 后端
用 Click、Docopt 和 Fire 庫寫你自己的命令行應用。對于這個月的 Python 專欄,我們有 3 個庫想介紹給希望為自己編寫命令行工具的 Python 使用者。

帶你了解3個Python命令行工具

用 Click、Docopt 和 Fire 庫寫你自己的命令行應用。

有時對于某項工作來說一個命令行工具就足以勝任。命令行工具是一種從你的 shell 或者終端之類的地方交互或運行的程序。GitCurl 就是兩個你也許已經很熟悉的命令行工具。

當你有一小段代碼需要在一行中執行多次或者經常性地被執行,命令行工具就會很有用。Django 開發者執行 ./manage.py runserver 命令來啟動他們的網絡服務器;Docker 開發者執行 docker-compose up 來啟動他們的容器。你想要寫一個命令行工具的原因可能和你一開始想寫代碼的原因有很大不同。

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

 

Click

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

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

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

  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() 修飾器聲明了一個 可選參數 ,而 @click.argument() 修飾器聲明了一個 必要參數。你可以通過疊加修飾器來組合可選和必要參數。echo() 方法將結果打印到控制臺。

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

 

Docopt

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

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

docstring 中的第二個元素是 Options:,對于在 Usages: 中提及的可選項和參數,它應當提供更多的信息。你的 docstring 的內容變成了你幫助文本的內容。

  1. """HELLO CLI
  2.  
  3. Usage:
  4. hello.py
  5. hello.py <name>
  6. hello.py -h|--help
  7. hello.py -v|--version
  8.  
  9. Options:
  10. <name> 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['<name>']:
  24. print(say_hello(arguments['<name>']))
  25. else:
  26. print(arguments)

在最基本的層面,Docopt 被設計用來返回你的參數鍵值對。如果我不指定上述的 name 調用上面的命令,我會得到一個字典的返回值:

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

這里可看到我沒有輸入 helpversion 標記并且 name 參數是 None。

但是如果我帶著一個 name 參數調用,say_hello 函數就會執行了。

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

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

 

Fire

Fire 是谷歌的一個命令行工具開發庫。尤其令人喜歡的是當你的命令需要更多復雜參數或者處理 Python 對象時,它會聰明地嘗試解析你的參數類型。

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

它的弱點在于輸出到控制臺的文檔。命令行中的 docstring 不會出現在幫助文本中,并且幫助文本也不一定標識出參數。

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

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

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

你還可以像標記一樣傳參,比如 --name=Rikki。

 

額外贈送:打包!

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

要打包我們***個例子中的命令行工具,將以下內容加到你的 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 替換成你的函數名稱。

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

現在你可以調用你的命令,就像這樣:

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

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

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2019-02-27 09:24:48

命令行文件Linux

2020-02-12 13:00:09

網速度測試工具開源工具

2020-12-10 16:16:08

工具代碼開發

2020-12-11 06:44:16

命令行工具開發

2018-05-04 09:15:35

PythonPlumbum命令行

2014-08-25 16:23:24

2023-06-09 07:45:29

Kuberneteskubectl

2015-07-29 10:34:50

Linux系統命令行工具

2015-07-30 11:04:08

Linux命令行工具

2015-07-30 11:24:47

Linux 系統命令行工具

2011-06-17 16:49:05

Cocoa蘋果

2018-05-02 08:06:12

2014-02-18 10:45:48

2014-04-09 11:05:11

2020-03-30 12:57:50

Linux命令行Markdown

2010-08-24 09:10:14

Linux命令行工具

2015-06-16 10:36:45

Linux命令行

2018-04-25 08:25:01

Linux命令行密碼管理器

2010-11-24 17:12:17

MySQL命令行

2013-12-09 14:29:13

OpenStack命令行工具API
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费黄色的视频 | 亚洲一区二区av | 亚洲精品在线免费播放 | 91大神在线资源观看无广告 | 日韩精品一区二 | 精品福利一区 | 91精品国产综合久久福利软件 | 色吊丝在线 | 国产亚洲精品久久久久久豆腐 | 黑人巨大精品欧美一区二区免费 | 日韩精品一区二区三区中文在线 | 91精品国产777在线观看 | 日韩视频在线免费观看 | 亚洲天堂999 | 日韩影院在线观看 | 国产精品综合视频 | 久热免费在线 | 欧美在线观看免费观看视频 | 成人欧美一区二区三区在线观看 | 午夜视频网站 | 男人av在线播放 | 日本xx视频免费观看 | 日韩av手机在线观看 | 久久精品久久久久久 | 日日干综合 | 一区二区三区国产 | 大香在线伊779 | 久久久久九九九九 | 国产成人一区二区三区精 | 久久国产成人午夜av影院武则天 | 亚洲高清网 | 女人精96xxx免费网站p | 懂色av一区二区三区在线播放 | 91精品国产乱码麻豆白嫩 | 亚洲性网 | 国产一区二区三区精品久久久 | 蜜桃传媒一区二区 | 美女午夜影院 | 9久9久 | 国产午夜精品久久久久免费视高清 | 天天综合网天天综合 |