Pip-pop

pip-grep主要是用于方便查看Requirements.txt中那些模块是安装了的。也就是通过输入的然后模块名称然后在Requirements.txt中进行查询。里面比较难的就是docopt这个模块。

docopt:

docopt
本质上是在 Python
中引入了一种针对命令行参数的形式语言,在代码的最开头使用
"""
"""文档注释的形式写出符合要求的文档,就会自动生成对应的parse。来看下具体使用的例子:

"""

Usage:

func_test1.py
para <abc>

func_test1.py
[-vc] <content>

func_test1.py
[-f] [FILE] ...

Options:

-h
--help

-v
--version

-c
--control

-f
--file_name

"""

from
docopt import docopt

if
__name__=="__main__":

argu=docopt(__doc__)

print(argu['FILE'])

1
首先构造__doc__的内容,也就是程序开头”””
”””的内容

2
构造Usage,所谓的Usage就是使用方法的格式,docopt会根据Usage里面的格式来解析命令行。格式第一个参数是func_test1.py,
这个就是文件名。第二个参数有集中形式,首先来看func_test1.py
para <pa> 这个para没有任何括号包含,证明是必须要带的选项。

使用的命令
python3
func_test1.py para abc, 此时命令匹配到func_test1.py
para <pa> 尖括号包括起来的pa就是要被赋值的参数,此时pa=abc

接来下再看func_test1.py
[-vc] <content>的格式,此时有括号将-vc包含起来,说明-vc是可选的,-vc也就是-v
-c 这两个参数必须包含在Options中。

使用的命令

python3
func_test1.py -vc python 或者是python3
func_test1.py python

最后来看func_test1.py
[-f] [FILE] ... 的格式,此时有一个...代表元素可以重复出现,最后解析的结果是一个列表。

使用的命令

python3
func_test1.py -f 1.txt 2.txt

此时FILE被赋值为[1.txt
2.txt], 是一个列表

最后docopt的返回结果是一个字典,返回的内容如下:

当对应的参数不存在的时候,对应的值会被置为False,
比如--control和--file_name。而--version则被置为True

python3
func_test1.py -v 1.txt

{'--control':
False,

'--file_name':
False,

'--version':
True,

'<pa>':
None,

'<content>':
'1.txt',

'FILE':
[],

'para':
False

同样的para置为True,pa被置为abc

python3
func_test1.py para abc

{'--control':
False,

'--file_name':
False,

'--version':
False,

'<pa>':
'abc',

'<content>':
None,

'FILE':
[],

'para':
True}

--file_name被置为True,FILE被置为[1.txt
2.txt]

python3
func_test1.py -f 1.txt 2.txt

{'--control':
False,

'--file_name':
True,

'--version':
False,

'<pa>':
None,

'<content>':
None,

'FILE':
['1.txt', '2.txt'],

'para':
False}

总结一下docopt的用法:

Usage中用到的一些标识的含义,正确地使用他们能够更好的完成解析任务:

[]

代表可选的元素,方括号内的元素可有可无

()

代表必须要有的元素,括号内的元素必须要有,哪怕是多个里面选一个。

|

互斥的元素,竖线两旁的元素只能有一个留下

代表元素可以重复出现,最后解析的结果是一个列表

[options]

指定特定的选项,完成特定的任务

另外格式方面Usage:和Options:必须要用一个空行隔开

像下面的这种格式会导致解析错误

"""

Usage:

func_test1.py
para <pa>

func_test1.py
[-vc] <content>

func_test1.py
[-f] [FILE] ...

Options:

-h
--help

-v
--version

-c
--control

-f
--file_name

"""

正确的格式:

"""

Usage:

func_test1.py
para <pa>

func_test1.py
[-vc] <content>

func_test1.py
[-f] [FILE] ...

Options:

-h
--help

-v
--version

-c
--control

-f
--file_name

"""

下面就是主体代码:

class
Requirements(object):

def
__init__(self, reqfile=None):

super(Requirements,
self).__init__()

self.path =
reqfile

self.requirements
= []

if reqfile:

self.load(reqfile)

def
__repr__(self):

return
'<Requirements \'{}\'>'.format(self.path)

def
load(self, reqfile):

if not
os.path.exists(reqfile):

raise
ValueError('The given requirements file does not exist.')

finder =
PackageFinder([], [], session=requests)

for
requirement in parse_requirements(reqfile, finder=finder,
session=requests):

if
requirement.req:

if not
getattr(requirement.req, 'name', None):

#
Prior to pip 8.1.2 the attribute `name` did not exist.

requirement.req.name
= requirement.req.project_name

self.requirements.append(requirement.req)

def
grep(reqfile, packages, silent=False):

try:

r =
Requirements(reqfile)

except
ValueError:

if not silent:

print('There
was a problem loading the given requirement file.')

exit(os.EX_NOINPUT)

for
req in r.requirements:

if req.name in
packages:

if not
silent:

print('Package
{} found!'.format(req.name))

exit(0)

if
not silent:

print('Not
found.')

exit(1)

def
main():

args
= docopt(__doc__, version='pip-grep')

kwargs =
{'reqfile': args['<reqfile>'], 'packages': args['<package>'],
'silent': args['-s']}

grep(**kwargs)

args保存的是输入的参数,reqfile就是Requirement.txt,package就是需要查询的模块名称。

1
Requirements中将所有在Requirement.txt中的模块保存在
self.requirements列表中

2
然后在grep中查找对应的模块名。

pip-grep的更多相关文章

  1. Python从2.6升级到2.7,使用pip安装module,报错:No Module named pip.log(转载)

    From:http://blog.csdn.net/iefreer/article/details/8086834 python升级后,使用pip安装module,错误: 错误原因:版本升级后,之前的 ...

  2. pip常用命令

    以flask为例. 1. 安装 # pip install flask 安装 flask. # pip install flask==1.0 安装 1.0版本的flask # pip install ...

  3. win10下Python3.6安装、配置以及pip安装包教程

    0.目录 1.前言 2.安装python 3.使用pip下载.安装包 3.1 安装Scrapy 3.2 安装PyQt 3.3 同时安装多个包 3.4 pip的常用命令 1.前言 之前在电脑上安装了py ...

  4. python3.6 pip 出现locations that require TLS/SSL异常解决方案

    在给CentOS服务器安装完Python3.6后,使用pip命令出现问题,提示说无法找到ssl模块. 上网查询后发现在安装Python3.6时没有安装openssl-devel依赖库,解决方案如下: ...

  5. 【QT】qt python install pip

    https://pip.pypa.io/en/stable/installing/ http://www.runoob.com/w3cnote/python-pip-install-usage.htm ...

  6. centos6.5安装python2.7、pip、numpy、scipy

    1..安装Development Tools yum groupinstall -y 'development tools' 2.安装SSL.bz2.zlib来为Python的安装做好准备工作 yum ...

  7. python3.7.2 pip 出现locations that require TLS/SSL异常处理方法

    centos7安装python3.7.2后,运行 pip3 install tornado 会报错 [root@localhost ~]# pip3 install tornado pip is co ...

  8. 用pip批量更新所有包

    p.s在先,事实证明,把电脑里所有的python包一次性更新是吃力不讨好的工作,不过,这是另一回事,如果你一定要这么做,根据http://stackoverflow.com/questions/272 ...

  9. [OSX] 使用 MacPorts 安装 Python 和 pip 指南

    Mac OS 未预装任何在 Unix/Linux 中常见的命令行包管理工具,Mac OS 中的 App Store 和自身的软件升级功能可以下载更新许多比较好的应用,但这些应用多数是满足普通消费者需求 ...

  10. Python pip常用指令

    pip listpip list --outdatedpip list --outdated | grep Jinja2pip uninstall pycurlpip show pycurlpip i ...

随机推荐

  1. html中插入php的方法

    .html文件是不可以被读取为php文件的必须修改后缀名为.php这个时候如果你在浏览器中调用此页面所有的HTML代码都会被正确显示 这个时候你可以在文件的任意为止插入<?php ?>作为 ...

  2. 谈一谈AGP

    typedef enum D3DPOOL { D3DPOOL_DEFAULT = 0, D3DPOOL_MANAGED = 1, D3DPOOL_SYSTEMMEM = 2, D3DPOOL_SCRA ...

  3. 个人shell积累

    1:bc 计算器2:ps:列出用户的进程3:more 有三种用法 $more filename 显示文件内容 $command | more 将command命令的输出分页显示 $more < ...

  4. jquery字符串转json

    var data; var json='[{"CityId":18,"CityName":"西安","ProvinceId&quo ...

  5. 自己动手开发IOC容器

    前两天写简历.写了一句:精通Spring IoC容器.怎么个精通法?还是自己动手写个IOC容器吧. 什么是IoC(Inversion of Control)?什么是DI(Dependency Inje ...

  6. C# SqlBulkCopy类批量导入数据

    特别注意  sqlbulkcopy.ColumnMappings.Add(dt.Columns[i].ColumnName, dt.Columns[i].ColumnName); 插入的时候列的顺序可 ...

  7. iOS中三种方式实现登录界面播放视频或gif效果

    现在app都做的越来越炫酷,各种动画效果,各种特效很好的提高了用户的体验.很多app在登录界面都使用了动画效果,比如Uber,Keep,QQ等等.这些动画效果基本都是使用gif或者MP4来实现的. 效 ...

  8. File 的基本操作

    package xinhuiji_day07; import java.io.File;import java.io.IOException; public class FileTest { /**  ...

  9. Docker-Compose 自动创建的网桥与局域网冲突解决方案

    环境: 使用docker-compose.yml 部署应用,docker 默认的网络模式是bridge ,默认网段是172.17.0.1/16  ,不巧的是我们局域网也使用的172.22. xx 网段 ...

  10. 探究 Redis 4 的 stream 类型

    redis 2 10 月初,Redis 搞了个大新闻.别紧张,是个好消息:Redis 引入了名为 stream 的新数据类型和对应的命令,大概会在年底正式发布到 4.x 版本中.像引入新数据类型这样的 ...