欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python命令行click參數(shù)用法解析

 更新時(shí)間:2019年12月19日 09:58:06   作者:Python探索牛  
這篇文章主要介紹了Python命令行click參數(shù)用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

這篇文章主要介紹了Python命令行click參數(shù)用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

一、前言

在概念上, click 把命令行分為 3 個(gè)組成:參數(shù)、選項(xiàng)和命令。

參數(shù) 就是跟在命令后的除選項(xiàng)外的內(nèi)容,比如 git add a.txt 中的 a.txt 就是表示文件路徑的參數(shù)

選項(xiàng) 就是以 - 或 -- 開頭的參數(shù),比如 -f、--file

命令 就是命令行的初衷了,比如 git 就是命令,而 git add 中的 add 則是 git 的子命令

二、參數(shù)

2.1 基本參數(shù)

基本參數(shù) 就是通過位置里指定參數(shù)值。

比如,我們可以指定兩個(gè)位置參數(shù) x 和 y ,先添加的 x 位于第一個(gè)位置,后加入的 y 位于第二個(gè)位置。那么在命令行中輸入 1 2的時(shí)候,分別對應(yīng)到的就是 x 和 y:

@click.command()
@click.argument('x')
@click.argument('y')
def hello(x, y):
  print(x, y)

2.2 參數(shù)類型

參數(shù)類型 就是將參數(shù)值作為什么類型去解析,默認(rèn)情況下是字符串類型。我們可以通過 type 入?yún)碇付▍?shù)類型。

click 支持的參數(shù)類型多種多樣:

  • str / click.STRING 表示字符串類型,這也是默認(rèn)類型
  • int / click.INT 表示整型
  • float / click.FLOAT 表示浮點(diǎn)型
  • bool / click.BOOL 表示布爾型。很棒之處在于,它會(huì)識(shí)別表示真/假的字符。對于 1、yes、y 和 true 會(huì)轉(zhuǎn)化為 True;0、no、n 和 false 會(huì)轉(zhuǎn)化為 False
  • click.UUID 表示 UUID,會(huì)自動(dòng)將參數(shù)轉(zhuǎn)換為 uuid.UUID 對象
  • click.FILE 表示文件,會(huì)自動(dòng)將參數(shù)轉(zhuǎn)換為文件對象,并在命令行結(jié)束時(shí)自動(dòng)關(guān)閉文件
  • click.PATH 表示路徑
  • click.Choice 表示選擇選項(xiàng)
  • click.IntRange 表示范圍選項(xiàng)

同 argparse 一樣,click 也支持自定義類型,需要編寫 click.ParamType 的子類,并重載 convert 方法。

2.3 文件參數(shù)

在基本參數(shù)的基礎(chǔ)上,通過指定參數(shù)類型,我們就能構(gòu)建出各類參數(shù)。

文件參數(shù) 是非常常用的一類參數(shù),通過 type=click.File 指定,它能正確處理所有 Python 版本的 unicode 和 字節(jié),使得處理文件十分方便。

@click.command()
@click.argument('input', type=click.File('rb')) # 指定文件為二進(jìn)制讀
@click.argument('output', type=click.File('wb')) # 指定文件為二進(jìn)制寫
def inout(input, output):
  while True:
    chunk = input.read(1024) # 此時(shí) input 為文件對象,每次讀入 1024 字節(jié)
    if not chunk:
      break
    output.write(chunk) # 此時(shí) output 為文件對象,寫入上步讀入的內(nèi)容

2.4 文件路徑參數(shù)

文件路徑參數(shù) 用來處理文件路徑,可以對路徑做是否存在等檢查,通過 type=click.Path 指定。不論文件名是 unicode 還是字節(jié)類型,獲取到的參數(shù)類型都是 unicode 類型。

@click.command()
@click.argument('filename', type=click.Path(exists=True)) # 要求給定路徑存在,否則報(bào)錯(cuò)
def hello(filename):
  click.echo(click.format_filename(filename))

如果文件名是以 - 開頭,會(huì)被誤認(rèn)為是命令行選項(xiàng),這個(gè)時(shí)候需要在參數(shù)前加上 -- 和空格,比如

$ python hello.py -- -foo.txt
-foo.txt

2.5 選擇項(xiàng)參數(shù)

選擇項(xiàng)參數(shù) 用來限定參數(shù)內(nèi)容,通過 type=click.Choice 指定。

比如,指定文件讀取方式限制為 read-only 和 read-write:

@click.command()
@click.argument('mode', type=click.Choice(['read-only', 'read-write']))
def hello(mode):
  click.echo(mode)

2.6 可變參數(shù)

可變參數(shù) 用來定義一個(gè)參數(shù)可以有多個(gè)值,且能通過 nargs 來定義值的個(gè)數(shù),取得的參數(shù)的變量類型為元組。

若 nargs=N,N為一個(gè)數(shù)字,則要求該參數(shù)提供 N 個(gè)值。若 N 為 -1 則接受提供無數(shù)量限制的參數(shù),如:

@click.command()
@click.argument('foo', nargs=-1)
@click.argument('bar', nargs=1)
def hello(foo, bar):
  pass

如果要實(shí)現(xiàn) argparse 中要求參數(shù)數(shù)量為 1 個(gè)或多個(gè)的功能,則指定 nargs=-1 且 required=True 即可:

@click.command()
@click.argument('foo', nargs=-1, required=True)
def hello(foo, bar):
  pass

2.7 從環(huán)境變量讀取參數(shù)

通過在 click.argument 中指定 envvar,則可讀取指定名稱的環(huán)境變量作為參數(shù)值,比如:

@click.command()
@click.argument('filename', envvar='FILENAME')
def hello(filename):
  print(filename)

執(zhí)行如下命令查看效果:

$ FILENAME=hello.txt python3 hello.py
hello.txt

而在 argparse 中,則需要自己從環(huán)境變量中讀取。

三、小節(jié)

本文講解了 click 中基本參數(shù)的用法,在此基礎(chǔ)上介紹了各種類型的參數(shù),最后說明了從環(huán)境變量中獲取參數(shù)值的寫法。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python如何給內(nèi)存和cpu使用量設(shè)置限制

    python如何給內(nèi)存和cpu使用量設(shè)置限制

    這篇文章主要介紹了python如何給內(nèi)存和cpu使用量設(shè)置限制,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python中的文件輸入輸出問題

    Python中的文件輸入輸出問題

    這篇文章主要介紹了Python中的文件輸入輸出問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 使用python檢查yaml配置文件是否符合要求

    使用python檢查yaml配置文件是否符合要求

    這篇文章主要介紹了使用python檢查yaml配置文件是否符合要求,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 完美解決python針對hdfs上傳和下載的問題

    完美解決python針對hdfs上傳和下載的問題

    這篇文章主要介紹了完美解決python針對hdfs上傳和下載的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • PyTorch張量拼接、切分、索引的實(shí)現(xiàn)

    PyTorch張量拼接、切分、索引的實(shí)現(xiàn)

    在學(xué)習(xí)深度學(xué)習(xí)的過程中,遇到的第一個(gè)概念就是張量,張量在pytorch中的計(jì)算十分重要,本文主要介紹了PyTorch張量拼接、切分、索引的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • 使用PySpider進(jìn)行IP代理爬蟲的技巧與實(shí)踐分享

    使用PySpider進(jìn)行IP代理爬蟲的技巧與實(shí)踐分享

    PySpider是一個(gè)基于Python的強(qiáng)大的開源網(wǎng)絡(luò)爬蟲框架,它使用簡單、靈活,并且具有良好的擴(kuò)展性,本文將介紹如何使用PySpider進(jìn)行IP代理爬蟲,并提供一些技巧和實(shí)踐經(jīng)驗(yàn),文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下
    2024-03-03
  • python定時(shí)按日期備份MySQL數(shù)據(jù)并壓縮

    python定時(shí)按日期備份MySQL數(shù)據(jù)并壓縮

    這篇文章主要為大家詳細(xì)介紹了python定時(shí)按日期備份MySQL數(shù)據(jù)并壓縮,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • Python全棧之迭代器和高階函數(shù)

    Python全棧之迭代器和高階函數(shù)

    這篇文章主要為大家介紹了Python之迭代器和高階函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • python處理yaml文件的操作方法

    python處理yaml文件的操作方法

    yaml文件是一種數(shù)據(jù)序列化語言,廣泛用于配置文件、日志文件、等,本文給大家介紹python處理yaml文件的操作方法,感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • 在python中以相同順序shuffle兩個(gè)list的方法

    在python中以相同順序shuffle兩個(gè)list的方法

    今天小編就為大家分享一篇在python中以相同順序shuffle兩個(gè)list的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12

最新評論