python 中的requirements.txt 文件的使用详情
作者: 梦想橡皮擦
实战场景
在部署Python应用时,需要把第三方库进行安装,这里可以使用requirements.txt
文件,其中记录了所有依赖包以及精确的版本号。
requirements.txt
文件在我们访问开源 Python项目的时候,极常见。
简单使用流程概述
使用pip freeze
命令生成requirements.txt
文件,
如下所示:
pip freeze > requirements.txt
请注意:每包都独占一行,然后是版本号。
生成的文件默认在控制台执行目录,也可以自定义目录,创建文件的时候增加文件目录即可
pip freeze > d:/requirements.txt
其中>
表示重定向,即 freeze 输出的内容送到requirements.txt
文件中。
迁移环境的时候,注意打包该文件,然后使用如下命令部署
pip install -r requirements.txt
生成 requirements.txt 文件潜在问题
如果生成该文件出现的时候出现 warning,建议使用python -m
去执行 pip freeze 命令。
如果你创建 Python 程序,或者安装模块时,未使用虚拟环境,那在生成requirements.txt
文件的时候,会将你本地所有的包都进行打包提取,部署前,需要人工进行筛选。
语法格式 在requirements.txt
文件中,可以只写第三方模块名称,不指定版本号,默认安装最新版本。
如果使用注释,使用#
加文字内容。
模块名称与版本号之间可以使用如下符号:
==
:等于>
:大于版本>=
:大于等于<
:小于版本<=
:小于等于版本~=
:兼容版本,使用任何大于或等于指定版本,但不大于当前发行系列的版本,例如~=1.4.3
可以匹配1.4.3
到1.4.9
,但是不能匹配1.5.0
。
在可选范围内,安装最新版本,当前最优先的依旧是等于的版本号。
可以使用逗号,
分隔两个条件,例如下述代码:
package_name >= 1.0, <=2.0
使用 requirements.txt 文件的好处
- 不需要每个包都使用 pip 进行安装
- 不需要确定第三方模块的版本号
备注
上文提及如果希望 requirements.txt 文件变得精简,可以使用虚拟环境实现隔离,它将用户的软件包和系统的软件包进行区分,允许我们为每个单独的程序安装模块。
常见的虚拟环境包如下所示:
- virtualenv
- pipenv
但上述介绍存在潜在的问题是:
requirements.txt
文件只包含一级依赖项及其版本,但如果我们的依赖项自身包含其它依赖项(二级以上),这些模块的版本不一定被锁定。
此时就可能会出现一个由于版本不对应的问题,导致程序崩溃。
当然使用下述命令可以解决该问题
pip freeze > requirements.txt
但是使用该命令会产生延伸问题,如果你希望删除一个模块,如何判断其关联依赖被删除
在其他编程语言中,会创建2个文件,一个用于定义依赖关系,另一个锁定所有的次级依赖项及其版本。
解决上述问题,可以使用pip-tools
中的 pip-compile
。
使用 pip-compile
该功能模块在pip-tools
中,所以需要先安装该工具。
python -m pip install pip-tools -i https://pypi.douban.com/simple/
安装完毕会在 Python 的 Scripts 文件夹中生成如下 exe 程序。
然后在你需要生成requirements.txt
的目录中建立一个requirements.in
文件,其中可以写入你需要的模块
requests == 2.27.0
然后执行pip-compile
命令,输出内容如下所示:
requirements.txt 文件代码如下:
# # This file is autogenerated by pip-compile with python 3.8 # To update, run: # # pip-compile # certifi==2021.10.8 # via requests charset-normalizer==2.0.12 # via requests idna==3.3 # via requests requests==2.27.0 # via -r requirements.in urllib3==1.26.9 # via requests
到此这篇关于python 中的requirements.txt 文件的使用详情的文章就介绍到这了,更多相关python requirements.txt内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!