<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
今天要介紹的 click 則是用一種你很熟知的方式來玩轉命令列。命令列程式本質上是定義引數和處理引數,而處理引數的邏輯一定是與所定義的引數有關聯的。那可不可以用函數和裝飾器來實現處理引數邏輯與定義引數的關聯呢?而 click 正好就是以這種方式來使用的。
本系列文章預設使用 Python 3 作為直譯器進行講解。
若你仍在使用 Python 2,請注意兩者之間語法和庫的使用差異哦~
click 是一個以儘可能少的程式碼、以組合的方式建立優美的命令列程式的 Python 包。它有很高的可設定性,同時也能開箱即用。
它旨在讓編寫命令列工具的過程既快速又有趣,還能防止由於無法實現預期的 CLI API 所產生挫敗感。它有如下三個特點:
3.1 業務邏輯
首先定義業務邏輯,是不是感覺到有些難以置信呢?
不論是 argparse 還是 docopt,業務邏輯都是被放在最後一步,但 click 卻是放在第一步。細想想 click 的這種方式才更符合人的思維吧?不論用什麼命令列框架,我們最終關心的就是實現業務邏輯,其它的能省則省。
我們以官方範例為例,來介紹 click 的用法和哲學。假設命令列程式的輸入是 name 和 count,功能是列印指定次數的名字。
那麼在 hello.py 中,很容易寫出如下程式碼:
def hello(count, name): """Simple program that greets NAME for a total of COUNT times.""" for x in range(count): click.echo('Hello %s!' % name)
這段程式碼的邏輯很簡單,就是迴圈 count 次,使用 click.echo 列印 name。其中,click.echo 和 print 的作用相似,但功能更加強大,能處理好 Unicode 和 二進位制資料的情況。
3.2 定義引數
很顯然,我們需要針對 count 和 name 來定義它們所對應的引數資訊。
count 對應為命令列選項 --count,型別為數位,我們希望在不提供引數時,其預設值是 1
name 對應為命令列選項 --name,型別為字串,我們希望在不提供引數時,能給人提示
使用 click,就可以寫成下面這樣:
from click import click @click.command() @click.option('--count', default=1, help='Number of greetings.') @click.option('--name', prompt='Your name', help='The person to greet.') def hello(count, name): ...
在上面的範例中:
不論是裝飾器的方式、還是各種預設行為,click 都是像它的介紹所說的那樣,讓人儘可能少地編寫程式碼,讓整個過程變得快速而有趣。
3.3 程式碼梳理
使用 click 的方式非常簡單,我們將上文的程式碼彙總下,以有一個更清晰的認識:
# hello.py import click @click.command() @click.option('--count', default=1, help='Number of greetings.') @click.option('--name', prompt='Your name', help='The person to greet.') def hello(count, name): """Simple program that greets NAME for a total of COUNT times.""" for x in range(count): click.echo('Hello %s!' % name) if __name__ == '__main__': hello()
若我們指定次數和名字:
$ python3 hello.py --count 2 --name Eric Hello Eric! Hello Eric!
若我們什麼都不指定,則會提示輸入名字,並預設輸出一次:
$ python3 hello.py Your name: Eric Hello Eric!
我們還可以通過 --help 引數檢視自動生成的幫助資訊:
Usage: hello.py [OPTIONS] Simple program that greets NAME for a total of COUNT times. Options: --count INTEGER Number of greetings. --name TEXT The person to greet. --help Show this message and exit.
click 的思路非常簡單,定義處理常式,通過它的裝飾器來定義引數。使用裝飾器的絕妙之處就在於把定義和繫結這兩個步驟合為一個步驟,使得整個過程變得如絲般順滑。
click 除了以 Pythonic 的方式讓命令列程式的實現變得更加優雅和好用外,還提供了比 argparse 和 docopt 都要強大的功能。
到此這篇關於Python命令列庫click的具體使用的文章就介紹到這了,更多相關Python命令列庫click內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45