開發(fā)命令行工具的十個 Click 庫高級參數(shù)
今天就來跟大家聊聊,如何用Click庫開發(fā)命令行工具的10個高級參數(shù)。一步步來,咱們先從簡單的開始,再到更高級的功能。
1. 定義基本命令
首先,使用Click庫,我們要定義一個最基本的命令。這是一個入門的例子。
# 導入click庫
import click
# 定義一個點擊裝飾器
@click.command()
# 定義函數(shù)處理程序邏輯
def hello():
"""簡單的命令,輸出Hello"""
click.echo("Hello!")
# 主函數(shù)調(diào)用
if __name__ == '__main__':
hello()
運行輸出:
Hello!
這里 click.echo() 是Click推薦使用的打印方式。它比標準 print 更加靈活和強大,尤其是涉及到Unicode或不同平臺間的兼容性問題時。
2. 添加簡單參數(shù)
現(xiàn)在我們往這個簡單的命令中加入一個可以輸入的名字參數(shù)。
import click
@click.command()
@click.argument('name') # 使用參數(shù)
def greet(name):
"""接收name參數(shù),打印個性化問候"""
click.echo(f"Hello, {name}!")
if __name__ == '__main__':
greet()
示例運行:
$ python app.py Alice
Hello, Alice!
這一步中,@click.argument('name') 這句代碼,允許命令行后面直接添加參數(shù)。
3. 帶類型的選項
我們可以給我們的命令行加入更多選擇項,并且指定這些項應該是什么樣的數(shù)據(jù)類型。
import click
@click.command()
@click.option('--age', type=int, help="Your age in years.") # 聲明age選項,要求為int類型
def display(age):
"""顯示年齡"""
click.echo(f"Your entered age is: {age}")
if __name__ == '__main__':
display()
運行:
$ python app.py --age 26
Your entered age is: 26
這樣,通過 --age 參數(shù)指定用戶的年齡,并在運行時得到反饋。
4. 默認值與幫助文本
接著,讓我們看看如何為選項設置默認值和幫助信息,這樣可以讓用戶更容易地了解命令該如何使用。
import click
@click.command()
@click.option('--temperature', default=20, help="Room temperature in degrees Celsius.")
def adjust_temp(temperature):
"""調(diào)整溫度設置"""
click.echo(f"The current room temperature is set to: {temperature}°C")
if __name__ == '__main__':
adjust_temp()
輸出結(jié)果(無指定值):
The current room temperature is set to: 20°C
5. 強制用戶確認
有些操作可能有破壞性,比如刪除文件之類的,那就可以加上用戶必須的交互確認了。
import click
@click.command()
@click.confirmation_option(prompt='Are you sure you want to proceed?')
def danger():
"""需要用戶確認的操作"""
click.echo("Action performed!")
if __name__ == '__main__':
danger()
在這個腳本執(zhí)行時,如果未輸入 yes 或 y,則該命令不會生效。
6. 接受多種輸入模式的值
如果你有一些選項是可以接受多個值的,比如說顏色列表,也可以很方便實現(xiàn)。
import click
@click.command()
@click.option('--colors', multiple=True, help="List of colors")
def show_colors(colors):
"""展示所有提供的顏色"""
for color in colors:
click.echo(f"You chose the color: {color}")
if __name__ == '__main__':
show_colors()
運行示例:
$ python app.py --colors red --colors green
You chose the color: red
You chose the color: green
7. 文件讀取和寫入支持
很多時候命令行需要處理文件輸入或者輸出。
import click
@click.command()
@click.argument('input_file', type=click.File('r'))
@click.argument('output_file', type=click.File('w'))
def copy(input_file, output_file):
"""拷貝內(nèi)容至另一文件"""
output_file.write(input_file.read())
click.echo('File copied successfully!')
if __name__ == '__main__':
copy()
這個腳本將讀取第一個文件的內(nèi)容,將其拷貝到另一個文件。
8. 組合多命令
有時候,一個命令行工具需要很多子命令。比如 git add, git commit 等等。
import click
@click.group()
def cli():
"""主組"""
@cli.command()
def initdb():
click.echo('Initialized the database')
@cli.command()
def dropdb():
click.echo('Dropped the database')
if __name__ == '__main__':
cli()
在這里使用 @click.group() 可以讓我們輕松定義一組子命令。
9. 回調(diào)機制與驗證
如果需要對用戶提供信息進行驗證,也可以很容易完成:
import click
def validate_age(ctx, param, value):
try:
if value < 0:
raise ValueError
return value
except ValueError:
raise click.BadParameter('Age must be a non-negative integer.')
@click.command()
@click.option('--age', callback=validate_age, type=int)
def process(age):
"""驗證年齡正確性"""
click.echo(f"Processed your valid age: {age}")
if __name__ == '__main__':
process()
當年齡不是正數(shù)或非整數(shù)時候?qū)崾居脩翦e誤信息。
10. 實際場景 - 文件查找器
下面是一個綜合的小案例,創(chuàng)建一個能夠遞歸搜索特定目錄下符合某種擴展名文件的應用程序:
import os
import click
def find_files(dir, ext):
"""實際查找文件方法"""
results = []
for dirpath, dirnames, filenames in os.walk(dir):
for filename in filenames:
if filename.endswith(ext):
results.append(os.path.join(dirpath, filename))
return results
@click.command()
@click.option('-d', '--dir', required=True, type=click.Path(exists=True), help='Directory to search.')
@click.option('-e', '--ext', required=True, help='File extension.')
def finder(dir, ext):
"""命令行應用:尋找擴展名為EXT的文件"""
files = find_files(dir, ext)
if not files:
click.echo('No matching files found.')
else:
for file in files:
click.echo(file)
if __name__ == '__main__':
finder()
這段程序會基于給出的目錄和擴展名去尋找相關聯(lián)的文件,并把它們打印出來。
總結(jié)
在這篇文章里,我們介紹了利用Click構(gòu)建命令行工具時可以運用到的十個高級特性。這些包括但不限于定義基礎命令,參數(shù)管理,選項配置如指定類型、提供默認值、強制確認、處理多重輸入以及文件輸入輸出功能。還涉及組合型子命令的設計、數(shù)據(jù)校驗回調(diào),最后結(jié)合所學到的知識構(gòu)建了一個實用的小型遞歸文件搜素器示例。