自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

大家都說好用的 Python 命令行庫(kù):click

開發(fā) 后端
在本系列前面幾篇文章中,我們分別介紹了 argparse 和 docopt 的主要功能和用法。它們各具特色,都能出色地完成命令行任務(wù)。argparse 是面向過程的,需要先設(shè)置解析器,再定義參數(shù),再解析命令行,最后實(shí)現(xiàn)業(yè)務(wù)邏輯。

 一、前言

在本系列前面幾篇文章中,我們分別介紹了 argparse 和 docopt 的主要功能和用法。它們各具特色,都能出色地完成命令行任務(wù)。argparse 是面向過程的,需要先設(shè)置解析器,再定義參數(shù),再解析命令行,最后實(shí)現(xiàn)業(yè)務(wù)邏輯。而 docopt 先用聲明式的語(yǔ)法定義出參數(shù),再過程式地解析命令行和實(shí)現(xiàn)業(yè)務(wù)邏輯。在一些人看來,這些方式都不夠優(yōu)雅。

[[281519]]

而今天要介紹的 click[2] 則是用一種你很熟知的方式來玩轉(zhuǎn)命令行。命令行程序本質(zhì)上是定義參數(shù)和處理參數(shù),而處理參數(shù)的邏輯一定是與所定義的參數(shù)有關(guān)聯(lián)的。那可不可以用函數(shù)和裝飾器來實(shí)現(xiàn)處理參數(shù)邏輯與定義參數(shù)的關(guān)聯(lián)呢?而 click 正好就是以這種方式來使用的。

本系列文章默認(rèn)使用 Python 3 作為解釋器進(jìn)行講解。若你仍在使用 Python 2,請(qǐng)注意兩者之間語(yǔ)法和庫(kù)的使用差異哦~

二、介紹click

是一個(gè)以盡可能少的代碼、以組合的方式創(chuàng)建優(yōu)美的命令行程序的 Python 包。它有很高的可配置性,同時(shí)也能開箱即用。

它旨在讓編寫命令行工具的過程既快速又有趣,還能防止由于無法實(shí)現(xiàn)預(yù)期的 CLI API 所產(chǎn)生挫敗感。它有如下三個(gè)特點(diǎn):

  • 任意嵌套命令
  • 自動(dòng)生成幫助
  • 支持運(yùn)行時(shí)延遲加載子命令

三、快速開始

3.1 業(yè)務(wù)邏輯

首先定義業(yè)務(wù)邏輯,是不是感覺到有些難以置信呢?

不論是 argparse 還是 docopt,業(yè)務(wù)邏輯都是被放在最后一步,但 click 卻是放在第一步。細(xì)想想 click 的這種方式才更符合人的思維吧?不論用什么命令行框架,我們最終關(guān)心的就是實(shí)現(xiàn)業(yè)務(wù)邏輯,其它的能省則省。

我們以官方示例為例,來介紹 click 的用法和哲學(xué)。假設(shè)命令行程序的輸入是 name 和 count,功能是打印指定次數(shù)的名字。

那么在 hello.py 中,很容易寫出如下代碼:

 

  1. def hello(countname): 
  2.     """Simple program that greets NAME for a total of COUNT times.""" 
  3.     for x in range(count): 
  4.         click.echo('Hello %s!' % name

這段代碼的邏輯很簡(jiǎn)單,就是循環(huán) count 次,使用 click.echo 打印 name。其中,click.echo 和 print 的作用相似,但功能更加強(qiáng)大,能處理好 Unicode 和 二進(jìn)制數(shù)據(jù)的情況。

3.2 定義參數(shù)

很顯然,我們需要針對(duì) count 和 name 來定義它們所對(duì)應(yīng)的參數(shù)信息。

  • count 對(duì)應(yīng)為命令行選項(xiàng) --count,類型為數(shù)字,我們希望在不提供參數(shù)時(shí),其默認(rèn)值是 1
  • name 對(duì)應(yīng)為命令行選項(xiàng) --name,類型為字符串,我們希望在不提供參數(shù)時(shí),能給人提示

使用 click,就可以寫成下面這樣:

 

  1. from click import click 
  2.  
  3. @click.command() 
  4. @click.option('--count'default=1, help='Number of greetings.'
  5. @click.option('--name', prompt='Your name'
  6.               help='The person to greet.'
  7. def hello(countname): 
  8.     ... 

在上面的示例中:

  1. 使用裝飾器的方式,即定義了參數(shù),又將之與處理邏輯綁定,這真是優(yōu)雅。和 argparse、docopt 比起來,就少了一步綁定過程
  2. 使用 click.command 表示 hello 是對(duì)命令的處理
  3. 使用 click.option 來定義參數(shù)選項(xiàng)
  • 對(duì)于 --count 來說,使用 default 來指定默認(rèn)值。而由于默認(rèn)值是數(shù)字,進(jìn)而暗示 --count 選項(xiàng)的類型為數(shù)字
  • 對(duì)于 --name 來說,使用 prompt 來指定未輸入該選項(xiàng)時(shí)的提示語(yǔ)
  • 使用 help 來指定幫助信息

不論是裝飾器的方式、還是各種默認(rèn)行為,click 都是像它的介紹所說的那樣,讓人盡可能少地編寫代碼,讓整個(gè)過程變得快速而有趣。

3.3 代碼梳理

使用 click 的方式非常簡(jiǎn)單,我們將上文的代碼匯總下,以有一個(gè)更清晰的認(rèn)識(shí):

 

  1. # hello.py 
  2. import click 
  3.  
  4. @click.command() 
  5. @click.option('--count'default=1, help='Number of greetings.'
  6. @click.option('--name', prompt='Your name'
  7.               help='The person to greet.'
  8. def hello(countname): 
  9.     """Simple program that greets NAME for a total of COUNT times.""" 
  10.     for x in range(count): 
  11.         click.echo('Hello %s!' % name
  12.  
  13. if __name__ == '__main__'
  14.     hello() 

若我們指定次數(shù)和名字:

 

  1. $ python3 hello.py --count 2 --name Eric 
  2. Hello Eric! 
  3. Hello Eric! 

若我們什么都不指定,則會(huì)提示輸入名字,并默認(rèn)輸出一次:

 

  1. $ python3 hello.py 
  2. Your name: Eric 
  3. Hello Eric! 

我們還可以通過 --help 參數(shù)查看自動(dòng)生成的幫助信息:

 

  1. Usage: hello.py [OPTIONS] 
  2.  
  3.   Simple program that greets NAME for a total of COUNT times. 
  4.  
  5. Options: 
  6.   --count INTEGER  Number of greetings. 
  7.   --name TEXT      The person to greet. 
  8.   --help           Show this message and exit. 

四、小結(jié)

click 的思路非常簡(jiǎn)單,定義處理函數(shù),通過它的裝飾器來定義參數(shù)。使用裝飾器的絕妙之處就在于把定義和綁定這兩個(gè)步驟合為一個(gè)步驟,使得整個(gè)過程變得如絲般順滑。

click 除了以 Pythonic 的方式讓命令行程序的實(shí)現(xiàn)變得更加優(yōu)雅和好用外,還提供了比 argparse 和 docopt 都要強(qiáng)大的功能。在接下來幾節(jié)中,我們將會(huì)逐步揭開它的面紗。

責(zé)任編輯:華軒 來源: HelloGitHub
相關(guān)推薦

2019-12-24 14:14:52

Google命令庫(kù)開源

2022-09-27 13:07:41

clickPython命令行

2021-11-08 10:45:07

Python命令工具

2025-03-18 10:30:44

2020-02-13 10:57:59

Python數(shù)據(jù)設(shè)計(jì)

2010-03-10 17:23:37

Python 命令行參

2015-07-01 09:15:46

linuxQuora命令行

2019-08-20 10:02:35

2022-02-17 18:21:47

工具HTTPie客戶端

2020-12-10 16:16:08

工具代碼開發(fā)

2020-12-11 06:44:16

命令行工具開發(fā)

2020-08-09 18:06:57

Linux系統(tǒng)工具

2010-03-11 15:55:23

Python命令行

2018-05-04 09:15:35

PythonPlumbum命令行

2021-07-16 16:47:40

命令行工具開源

2018-01-29 20:12:11

python翻譯命令行

2022-08-01 08:30:26

Python命令行

2010-11-16 11:50:21

oracle命令行登錄

2011-01-18 19:11:26

Postfix命令行

2019-08-27 09:03:13

工具插件開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)