别再用 requirements.txt 来管理依赖了

在我第一次用到 requirements.txt 时,是在一个虚拟环境中,我使用 pip freeze > requirements.txt 就把项目中的依赖项导出到了 txt 文件中,然后上传到 GitHub,别人在使用该项目时可以使用 pip install -r requirements.txt 就可以了,很方便不是吗。

不过,这样管理依赖的方式也并不完美。

比如说,我这个项目就依赖一个 Django,结果导出的 requirements.txt 却有这么多:

❯ pip freeze
asgiref==3.5.0
backports.zoneinfo==0.2.1
Django==4.0.1
sqlparse==0.4.2
~/tmp ❯

也就是说,你安装依赖项 A ,它恰好有 B 作为子依赖项,B 又依赖 C。有时候你只是测试目的或者为了一个小 demo 也使用 pip 安装了一些包,那么这些依赖也会在 pip freeze 的列表中。

一段时间后,你在 requirements.txt 中看到的是 A、B、C、D、E、F、G、H,你并不知道直接或间接安装了哪些依赖项,因此现在更新甚至删除 F 成为一个问题,你必须搜索才能知道 F 是作为子依赖项安装的。最终会留下陈旧的依赖项并堆积垃圾或花费大量时间进行搜索并删除所有未使用的内容。

如何解决这个问题呢?

那就是用 pip-tools,具体方法如下:

1、安装

首先,我们来创建一个虚拟环境,然后使用 pip 安装 pip-tools:

python3 -m venv venv
source venv/bin/activate
pip install pip-tools
2、创建 requirements.in 文件

现在,我们需要创建一个 requirements.in 文件,并且只包含项目的直接依赖项。每次您想要更新或包含依赖项时,都必须先修改 requirements.in 。它与 requirements.txt 的区别也很明显,那就是只包含直接依赖的库,也可以指定版本:

8c7d72cbf4305024883e019ab8f5a0e2.png
3、编译 requirements.in

pip-compile requirements.in 可以直接生成 requirements.txt,但是你会发现这个 requirements.txt 跟 pip freeze 生成的有很大不同,你可以看到某个包是通过那个包引入的,依赖关系一目了然:

de4b8159a8462719154a582e952f0a8c.png

就这样,之前提到的问题已经不存在了,你拥有了管理依赖所需的所有信息。

4、额外功能

除此之外,pip-tools 还提供了其他有用的功能:

1、升级包。

以 Django 为例:

pip-compile --upgrade-package django

这将自动更新您的 requirements.txt 文件,包括依赖项的修改。

2、同步包

为了使 virtualenv 与当前的 requirements.txt 文件同步,您可以简单地运行以下命令:

pip-sync -a requirements.txt

这将先询问,当你输入 y 时,会在虚拟环境中安装、升级或卸载,最终与 requirements.txt 文件包含的包保持一致。

有关 pip-tools 的更多详细信息,请参阅其文档[1]

最后的话

好了,你又学到了一个新的技能 pip-tools,是精细化管理依赖库的必备工具,如果觉得文章有帮助的话,请点赞、在看、转发三连支持,感谢老铁。

53003bb784ed3c0491dc97c44b705c18.png

参考资料

[1]

文档: https://github.com/jazzband/pip-tools

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值