一、序言
接下來要詳細介紹的click乃是以一種你也很熟識的方式去輕松玩cmd。cmd程序流程實質上是界定主要參數與處理主要參數,而解決參數邏輯性肯定是和所界定的主要參數相關聯的。那可不可以用函數公式和裝飾器來達到解決主要參數邏輯界定主要參數的聯系呢?而click正好便是以這樣的方式來所使用的。
本系列產品文章內容默認設置應用Python3做為編譯器進行介紹。
若是你依然在應用Python2,一定要注意二者之間詞匯和庫的應用差別哦~
二、詳細介紹
click是這種以盡量少的編碼、以組合方法建立優美cmd流程的Python包。它有著很高的可配置性,同時也可以開箱即用。
它致力于讓撰寫命令行工具的一個過程既迅速又有趣,能防止因為無法完成預想的CLIAPI所形成失落感。它有以下三個方面:
隨意嵌入指令
一鍵生成協助
適用運行中延遲加載子指令
三、快速開始
3.1領域模型
最先界定領域模型,是不是覺得到有一些難以想象呢?
無論是argparse還是docopt,領域模型也是被放到最后,但click則是放到首先。細想一想click的這種方法才更加符合人的思想吧?無論用哪種cmd架構,大家最后關注的便是完成領域模型,其他的精打細算。
就以官方網實例為例子,來講解click的使用方法和哲學。假定cmd流程的鍵入是name和count,作用是打印出特定頻次的名稱。
那在hello.py中,非常容易寫下如下所示編碼:
defhello(count,name): """SimpleprogramthatgreetsNAMEforatotalofCOUNTtimes.""" forxinrange(count): click.echo('Hello%s!'%name)
這段代碼的邏輯很簡單,就是循環count次,使用click.echo打印name。其中,click.echo和print的作用相似,但功能更加強大,能處理好Unicode和二進制數據的情況。
3.2定義參數
很顯然,我們需要針對count和name來定義它們所對應的參數信息。
count對應為命令行選項--count,類型為數字,我們希望在不提供參數時,其默認值是1
name對應為命令行選項--name,類型為字符串,我們希望在不提供參數時,能給人提示
使用click,就可以寫成下面這樣:
fromclickimportclick @click.command()@click.option('--count',default=1,help='Numberofgreetings.') @click.option('--name',prompt='Yourname',help='Thepersontogreet.')defhello(count,name):...
在上面的示例中:
使用裝飾器的方式,即定義了參數,又將之與處理邏輯綁定,這真是優雅。和argparse、docopt比起來,就少了一步綁定過程
使用click.command表示hello是對命令的處理
使用click.option來定義參數選項
對于--count來說,使用default來指定默認值。而由于默認值是數字,進而暗示--count選項的類型為數字
對于--name來說,使用prompt來指定未輸入該選項時的提示語
使用help來指定幫助信息
不論是裝飾器的方式、還是各種默認行為,click都是像它的介紹所說的那樣,讓人盡可能少地編寫代碼,讓整個過程變得快速而有趣。
3.3代碼梳理
使用click的方式非常簡單,我們將上文的代碼匯總下,以有一個更清晰的認識:
#hello.py importclick @click.command() @click.option('--count',default=1,help='Numberofgreetings.') @click.option('--name',prompt='Yourname', help='Thepersontogreet.') defhello(count,name): """SimpleprogramthatgreetsNAMEforatotalofCOUNTtimes.""" forxinrange(count): click.echo('Hello%s!'%name) if__name__=='__main__': hello()
若我們指定次數和名字:
$python3hello.py--count2--nameEric HelloEric! HelloEric! 若我們什么都不指定,則會提示輸入名字,并默認輸出一次: $python3hello.py Yourname:Eric HelloEric! 我們還可以通過--help參數查看自動生成的幫助信息: Usage:hello.py[OPTIONS] SimpleprogramthatgreetsNAMEforatotalofCOUNTtimes. Options: --countINTEGERNumberofgreetings. --nameTEXTThepersontogreet. --helpShowthismessageandexit.
四、小結
click的思路非常簡單,定義處理函數,通過它的裝飾器來定義參數。使用裝飾器的絕妙之處就在于把定義和綁定這兩個步驟合為一個步驟,使得整個過程變得如絲般順滑。
綜上所述,這篇文章就給大家介紹到這里了,希望可以給大家帶來幫助。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/128800.html
摘要:如果設置為,命令將激活模式,執行會啟用交互式調試器和代碼自動重載。也可以通過變量單獨控制,表示啟用,表示禁用通過設置環境變量略通過設置環境變量略自定義命令命令基于庫實現。 應用發現 flask命令在Flask庫安裝后可使用,使用前需要正確配置FLASK_APP環境變量以告知用戶程序所在位置。不同平臺設置方式有所不同。 Unix Bash (Linux, Mac, etc.): $ ex...
摘要:的框架是網易團隊自己開發的一個圖像識別框架,這個框架的祖宗就是一種新穎的圖形腳本語言。基本操作方法除了跨平臺的還有平臺特定的,比如安卓平臺蘋果平臺平臺這里我們來詳細說說這些模塊。 ...
摘要:首先,我們必須聲明自定義指令的名稱。這基本上注冊了一個名為的全局自定義指令接下來,我們使用一些參數添加函數,這允許我們引用元素指令綁定,獲取傳遞給指令的值并標識使用該指令的組件。 showImg(https://segmentfault.com/img/bVbfzuo?w=828&h=838); 您是否曾想過按住按鈕幾秒鐘才能在Vue應用程序中執行某個功能? 您是否曾想在應用程序上創建...
摘要:首先,我們必須聲明自定義指令的名稱。這基本上注冊了一個名為的全局自定義指令接下來,我們使用一些參數添加函數,這允許我們引用元素指令綁定,獲取傳遞給指令的值并標識使用該指令的組件。 showImg(https://segmentfault.com/img/bVbfzuo?w=828&h=838); 您是否曾想過按住按鈕幾秒鐘才能在Vue應用程序中執行某個功能? 您是否曾想在應用程序上創建...
閱讀 919·2023-01-14 11:38
閱讀 891·2023-01-14 11:04
閱讀 750·2023-01-14 10:48
閱讀 2039·2023-01-14 10:34
閱讀 956·2023-01-14 10:24
閱讀 833·2023-01-14 10:18
閱讀 506·2023-01-14 10:09
閱讀 583·2023-01-14 10:02