命令行神器 Click教程A篇

简介: 摘要 这里介绍一个快速创建命令行的神器click,是一个用Python开发的第三方模块。 相比较Argparse来创建命令行或者参数解析。click确实方便了很多。 官网 的介绍如下:Click is a Python package for creating beautiful command line interfaces in a co

摘要

这里介绍一个快速创建命令行的神器click,是一个用Python开发的第三方模块。
相比较Argparse来创建命令行或者参数解析。click确实方便了很多。


官网 的介绍如下:

Click is a Python package for creating beautiful command line 
interfaces in a composable way with as little code as necessary.
It’s the “Command Line Interface Creation Kit”. It’s highly 
configurable but comes with sensible defaults out of the box.

安装

官网建议通过virtualevn来安装,关于virtualenv安装Python第三方包的详细教程和注意问题请参考 Centos 下 python 纯净虚拟环境

安装命令

pip install click

安装完成验证

root@pts/3 $ python
Python 2.7.5 (default, Nov 20 2015, 02:00:19)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-4)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import click
>>> click.__version__
'6.6'
>>>

使用

command

这里先参考官网给出来的一个例子:

## python case script
root@pts/3 $ cat case-1.py
#!/usr/bin/env python
#encoding:  utf-8
#author:    Colin
#date:      2016-12-29
#desc:
#

import click

@click.command()
def hello():
    click.echo('Hello World!')

if __name__ == '__main__':
    hello()

## execute
root@pts/3 $ python case-1.py
Hello World!

root@pts/3 $ python case-1.py --help
Usage: case-1.py [OPTIONS]

Options:
  --help  Show this message and exit.

这里发现 click 自动添加了一个 --help 的参数

python-click-case-1.png


option

这里介绍用 option 构造命令行参数, 再上面的例子基础上继续修改

## scripts
import click

@click.command()
@click.option('--name', prompt='enter your name here: ',
            help='greet to given name')
def hello(name):
    click.echo('Hello World! hello %s' % name)

if __name__ == '__main__':
    hello()


## execute script
root@pts/3 $ python case-2.py
enter your name here: : Colin
Hello World! hello Colin

root@pts/3 $ python case-2.py --name Colin
Hello World! hello Colin

root@pts/3 $ python case-2.py --name=James
Hello World! hello James

root@pts/3 $ python case-2.py --help
Usage: case-2.py [OPTIONS]

Options:
  --name TEXT  greet to given name
  --help       Show this message and exit.

脚本结果如下:
python-click-case-2.png

关于option使用过程中遇到的几个问题:

  • 参数名称只能是--xxxx,比如要以`–“开头,不然报错如下:

python-click-option-error-1.png

group

使用 group 可以把多个函数组合成子命令;

有两种方式:

A:

通过 `@click.group()` 装饰器定义一个函数 A,最后通过 
`A.add_command(hello)` 把别的函数加入到 `group` 函数中去。
注意 `hello` 是脚本中定义的一个命令行函数

B:

通过 `@click.group()` 装饰器定义一个函数 B,在定义一般命令行函数的时候,用 
`@B.command()` 来替代 `@click.command()` 装饰命令行函数`hello`

这里给出第一个方式的结果。第二个可以自己尝试看看结果是否一致。具体例子详见:

## python script
import click


@click.group()
def gpfun():
    pass

@click.command()
@click.option('--name', prompt='enter your name here: ',
            help='greet to given name')
def hello(name):
    click.echo('Hello World! hello %s' % name)

gpfun.add_command(hello)

if __name__ == '__main__':
    gpfun()


## execute
root@pts/3 $ python case-3.py --help
Usage: case-3.py [OPTIONS] COMMAND [ARGS]...

Options:
  --help  Show this message and exit.

Commands:
  hello

root@pts/3 $ python case-3.py hello --help
Usage: case-3.py hello [OPTIONS]

Options:
  --name TEXT  greet to given name
  --help       Show this message and exit.

root@pts/3 $ python case-3.py hello --name='Colin'
Hello World! hello Colin

这里注意多了个gpfun函数,其上的装饰器是@click.group()

另外注意最下面的 if 判断里面的函数调用变成了 gpfun()

脚本结果如下:

python-click-case-3.png

其他详细的用法待续…


简书地址:命令行神器 Click教程A篇



公众号: DailyJobOps

    公众号: DailyJobOps    

目录
相关文章
|
机器学习/深度学习 人工智能 自然语言处理
|
4月前
|
人工智能 编解码 搜索推荐
16个AI Logo 设计工具大盘点:技术解析、Logo格式对比与实用推荐
本文介绍了品牌标志(Logo)的重要性,并盘点了多款免费且好用的 Logo 生成工具,分析其输出尺寸、格式及适用场景,帮助无设计基础的用户选择合适工具,高效制作满足不同用途的 Logo。
441 0
|
Web App开发 Ubuntu
解决Ubuntu14.04安装Chrome浏览器打不开的问题
解决Ubuntu14.04安装Chrome浏览器打不开的问题
946 0
|
机器学习/深度学习 人工智能 网络架构
Transformer原理解析——一种Open AI和DeepMind都在用的神经网络架构
Transformer模型是一种日益流行的神经网络结构。它最近被OpenAI用于他们的语言模型中。与此同时,近期也被DeepMind用于它们的程序“星际争霸”中击败了一名顶级职业星际玩家。 Transformer模型的开发是为了解决序列转换及神经机器翻译问题。
9173 0
|
Python
python中动态导入文件的方法
python中动态导入文件的方法
663 0
python中动态导入文件的方法
|
前端开发 JavaScript 搜索推荐
React 中服务端渲染和客户端渲染的区别
【8月更文挑战第31天】
334 0
|
存储 缓存 关系型数据库
Django后端架构开发:缓存机制,接口缓存、文件缓存、数据库缓存与Memcached缓存
Django后端架构开发:缓存机制,接口缓存、文件缓存、数据库缓存与Memcached缓存
339 0
|
算法 安全 程序员
详解 DES加密技术 | 凯撒密码 | 栅栏密码
详解 DES加密技术 | 凯撒密码 | 栅栏密码
918 0
详尽分享马卡龙色色卡及其十六进制代码
详尽分享马卡龙色色卡及其十六进制代码
653 0
|
Kubernetes 负载均衡 算法
Kubernetes最佳实战案例:优化容器化部署与扩展性
Kubernetes最佳实战案例:优化容器化部署与扩展性