前言
在上一篇文章中,我们初步掌握了 click 的简单用法,并了解到它与 argparse 和 docopt 的不同。接下来,将深入介绍 click 的各类用法,以让你能轻松打造复杂的命令行程序。
在概念上, click 把命令行分为 3 个组成:参数、选项和命令。
参数就是跟在命令后的除选项外的内容,比如git add a.txt中的a.txt就是表示文件路径的参数选项就是以-或--开头的参数,比如-f、--file命令就是命令行的初衷了,比如git就是命令,而git add中的add则是git的子命令
1 | 本系列文章默认使用 Python 3 作为解释器进行讲解。 |
参数
基本参数
基本参数 就是通过位置里指定参数值。
比如,我们可以指定两个位置参数 x 和 y ,先添加的 x 位于第一个位置,后加入的 y 位于第二个位置。那么在命令行中输入 1 2的时候,分别对应到的就是 x 和 y:
1 |
|
参数类型
参数类型 就是将参数值作为什么类型去解析,默认情况下是字符串类型。我们可以通过 type 入参来指定参数类型。
click 支持的参数类型多种多样:
str/click.STRING表示字符串类型,这也是默认类型int/click.INT表示整型float/click.FLOAT表示浮点型bool/click.BOOL表示布尔型。很棒之处在于,它会识别表示真/假的字符。对于1、yes、y和true会转化为True;0、no、n和false会转化为Falseclick.UUID表示 UUID,会自动将参数转换为uuid.UUID对象click.FILE表示文件,会自动将参数转换为文件对象,并在命令行结束时自动关闭文件click.PATH表示路径click.Choice表示选择选项click.IntRange表示范围选项
同 argparse 一样,click 也支持自定义类型,需要编写 click.ParamType 的子类,并重载 convert 方法。
官网提供了一个例子,实现了一个整数类型,除了普通整数之外,还接受十六进制和八进制数字, 并将它们转换为常规整数:
1 | class BasedIntParamType(click.ParamType): |
文件参数
在基本参数的基础上,通过指定参数类型,我们就能构建出各类参数。
文件参数 是非常常用的一类参数,通过 type=click.File 指定,它能正确处理所有 Python 版本的 unicode 和 字节,使得处理文件十分方便。
1 |
|
文件路径参数
文件路径参数 用来处理文件路径,可以对路径做是否存在等检查,通过 type=click.Path 指定。不论文件名是 unicode 还是字节类型,获取到的参数类型都是 unicode 类型。
1 |
|
如果文件名是以 - 开头,会被误认为是命令行选项,这个时候需要在参数前加上 -- 和空格,比如
1 | $ python hello.py -- -foo.txt |
选择项参数
选择项参数 用来限定参数内容,通过 type=click.Choice 指定。
比如,指定文件读取方式限制为 read-only 和 read-write:
1 |
|
可变参数
可变参数 用来定义一个参数可以有多个值,且能通过 nargs 来定义值的个数,取得的参数的变量类型为元组。
若 nargs=N,N为一个数字,则要求该参数提供 N 个值。若 N 为 -1 则接受提供无数量限制的参数,如:
1 |
|
如果要实现 argparse 中要求参数数量为 1 个或多个的功能,则指定 nargs=-1 且 required=True 即可:
1 |
|
从环境变量读取参数
通过在 click.argument 中指定 envvar,则可读取指定名称的环境变量作为参数值,比如:
1 |
|
执行如下命令查看效果:
1 | $ FILENAME=hello.txt python3 hello.py |
而在 argparse 中,则需要自己从环境变量中读取。
小节
本文讲解了 click 中基本参数的用法,在此基础上介绍了各种类型的参数,最后说明了从环境变量中获取参数值的写法。
在下一篇文章中,我们来继续深入了解 click 的功能,看看它都支持什么样的“选项”。
相关文章
- Python 命令行之旅:初探 argparse
- Python 命令行之旅:深入 argparse(一)
- Python 命令行之旅:深入 argparse(二)
- Python 命令行之旅:使用 argparse 实现 git 命令
- Python 命令行之旅:初探 docopt
- Python 命令行之旅:深入 docopt
- Python 命令行之旅:使用 docopt 实现 git 命令
- Python 命令行之旅:初探 click
- Python 命令行之旅:深入 click(一)
- Python 命令行之旅:深入 click(二)
- Python 命令行之旅:深入 click(三)
- Python 命令行之旅:深入 click(四)
- Python 命令行之旅:使用 click 实现 git 命令
- Python 命令行之旅:初探 fire
- Python 命令行之旅:深入 fire(一)
- Python 命令行之旅:深入 fire(二)
- Python 命令行之旅:使用 fire 实现 git 命令
- Python 命令行之旅:argparse、docopt、click 和 fire 总结篇
- Python 命令行大乱斗
