什么是命令行参数_快速上手Python命令行模块Click

1949b646dd959c8fbcf95f61f37ba728.png

快速上手 Python 命令行模块 Click

关于Click?

说下 Click 模块是干啥的,简单说,它就是把我们的 Python 脚本的一些函数,通过 添加带有 Click 关键字的装饰器进行装饰进而将函数调用的形式转化为命令行传参的形式然后执行。听不懂也没关系,我们会一步一步来,基本上按照我的实际应用情况来写的。 本文不会涉及太多复杂的语法和理论,将会用通俗的语言和大家进行分享。

安装

a027eef501276bd895c4cb3bd16313b3.png

一个简单的例子

首先我们创建一个demo.py

c2d1004fa91fc59ccd73c66a6d20e3ff.png

装饰器@click.command()会将我们的函数包装成 click 对象,然后我们可以在函数中调用 click 的一些方法,常用的是click.echo,它的作用类似我们的 print,输出用的。

通过命令行我们可以这样运行这行代码

85ae8a7773587a73bd55a16493a4f0df.png

好了,我们的第一个例子完事了,我们发现此时的代码使用不使用 click好像没什么区别。 接下来我们就要对它进行拓展了,如果我们需要传入一个数字,然后打印这个时候,我们的代码就可以这样写了。

传入我们的第一个参数

8837600c82e15a8ccf0dc51a0c4d6532.png

这里我们前面代码的基础上给函数 main 增加了 @click.option 装饰器。

接下来说下这几个参数的含义 -n:表示我们在命令行指定参数名的时候使用它即可,注意是一个短'-' --num:是第一个参数的完整名称,我们在程序中接收值的时候使用它。注意是二个短'-'。 help:在命令行输入 "python3 demo.py --help" 的时候,它可以提示我们这个程序有哪些命令可以用。和我们使用命令行一个道理的。 然后我们的函数main的参数名就是,我们要接收的参数的完整名称,同时通过click.echo打印出来。,f"{num=}" 是 Python 3.8 以后的语法糖,如果 num=3 那么它等价于 num = 3。 最后记得在 __main__ 里执行我们的 main 方法。 好了,介绍完了代码,我们可以运行了,运行示例: 首先假设我们不知道它有几个参数。

8b492e8ce00d554c7dd5bba4ca12910e.png

通过help我们可以得到如下信息

40914ae2677945ab2d8fe67ac0a72a11.png

Usage: 对应我们当前文件名

Options: 是一行一个参数,一个参数分为-开头的缩略参数,和--开头的完整参数名。

然后我们后面可以看到它的类型是 TEXT。紧接着就是该参数的提示信息,通过 help 我们可以设置。

64d457e818080b34d1cf88f70509fde7.png

或者

1e1d4e5aba48889499ac564ccc54e770.png

上面两者输入方法是等价的使用哪个都行。

现在思考一个问题,如果我们需要 num 的值为数字类型的 3 怎么弄呢?

声明参数类型

这里提供两种方法(当然不仅两种) 方法一:使用 type 关键字,type 就是 python 里的类型

264926e0b6537056b075f795fae75a79.png

再次执行代码

1e5da5f1f93e4b95a84db9c31c694107.png

同时查看 help 信息的时候 TEXT 变为了 INTEGER。

方法二:使用 default 关键字,指定默认值为 1

d1f8fc5ee1cf7547777d432435fb1d3a.png

将 default 的值设置为数字,我们的命令行就知道了我们的参数类型为 int,

这里处理指定了参数类型,还设定了默认值。设定为默认值的参数,可以不指定其值,这时候会使用默认值。

如果我们使用 help 查看信息会发现和上面的方法一没什么区别的。这时候我们可以通过指定另外一个关键字,让它在 help 信息里显示默认值

c4bdb268413943e448b93ecfa6b1fa9e.png

通过加入 show_default 我们可以让 default 的值在 help 信息中显示了,内容格式如下:

2535720908c7871e8ad4cfadde3cc662.png

再加一个参数

在上面代码的基础上对代码进行部分修改,主要是新添加一个参数 id。

3f261e9fbf21263528d285cfcaaf2c47.png

给之前的函数再添加@click.option装饰器即可。

这里我添加了的参数为 id ,因为一般情况下 id 是不能为空的,所以我们就可以通过required = True对它进行限制,表示该参数为必传参数。如果不传就出现错误

1eca2611b62c24449e586a6c38b494e8.png

正确的使用方法应该是

1cfa0ac40844635057c93cfe839da025.png

到目前为止一个简答的命令行工具就生成了。接下来说下我用它做过什么事情。

处理实际问题

现在我们有个需求,根据用户名去 mongo 数据库中查找对应的用户登录信息,最终的生成信息格式如下:

6de6f31280eeba8f0e7172773d25d013.png

一开始我是通过在 python 脚本中加个配置文件,然后通过配置文件的形式进行用户名的修改,但是这种方式不灵活,每次都需要重新运行 Python 代码。或者我们还可以使用 fastapi搭建一个RESTful api的服务,但是我的懒得搭这个服务。最终我选择使用命令行的形式去运行。使用的模块就是今天说的这个 click 模块。

接下来写一段需要代码:

cf207a18ed751879be44f7b832cefaf0.png

通过上面的码我们就可以通过命令行的形式进行查询了。

989854034ece7b8a8a2e89619bdeb35d.png

非常的方便。 如果这个时候,我需要一个临时添加用户的功能,就需要重新写一个函数了, 然后我们在命令行中如何控制两个函数的运行呢?这就是接下来要说的组。

创建组的形式

所谓的创建组,就是通过一个主入口函数,去关联其他的函数,然后其他的函数名可以作为命令直接使用。 好了首先创建一个主入口函数

7628246c5a8cf5e61374f36c4f8c18cb.png

这个时候我们发现 main 上面的装饰器变为了@click.group()。

我们通过它准备创建一个命令行组。接下来我们开始创建组成员,所谓的组成员就是一个函数。

efef315d4285d7faddf68505f7014771.png

这个组成员的作用和它的函数名是一样的就是查询用户信息。

这里需要注意的是组成员的装饰器由原来的

@click.command变为了@main.command。

main 就是上面 main 方法名。然后同样下面的 option 是声明一些参数。

接下来我们创建第二个组成员,用来添加用户信息。

cf16e90a6d143bc04de413f639964a15.png

首先通过@main.command()将它加入到组。然后就是 option 一系列添加参数的操作。这个具体的参数信息上面都说了这里就不提了。好了我们就创建这两个成员, 如果需要其他的功能,比如说删除用户,可以继续添加一个 delete_user 函数,以此类推。

下面我就说下如何执行上面的两个成员函数。

首先,先看下它的 help 命令,都有什么内容,一般不知道一个命令行应用有什么命令参数的我时候我们可以使用它。

845a103d7c6e54d6abcb60c116ade59f.png

输出以下内容

c74d37e5067e460c011b837d7e8d77a7.png

其中 Commands 就是我们的成员函数的调用命令,需要注意一下它将函数原来的"_"变为了“-”。

然后我们就可以调用查询方法了

3e4b8873155fa54b942925ffc277639c.png

然后我们就可以得到结果

6341cd1329587b410557bbaaddcda998.png

同样的调用添加用户信息的方法。

ab4a82f04b6473caf6f9867e7209bf70.png

因为-t不是必传参数所以我们可以忽略,使用默认值"phone"。

好了,这就是今天要说的内容,基本上够日常操作了。

877d581bd1d7ef94c6a7c66d80f40de6.gif
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值