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