0

0

Python requirements.txt 的逐步淘汰路径

舞姬之光

舞姬之光

发布时间:2026-02-23 19:38:03

|

491人浏览过

|

来源于php中文网

原创

requirements.txt 不再被推荐作为生产依赖管理方式,因其仅为扁平化导出产物,缺乏来源追踪、环境区分、条件依赖支持及可重现锁机制;应改用 pyproject.toml 声明依赖并配合锁文件(如 poetry.lock)。

python requirements.txt 的逐步淘汰路径

requirements.txt 为什么不再被推荐作为生产依赖管理方式

Python 官方(PEP 621、pip 23.1+)和主流工具链(poetry、pip-tools、uv)已明确将 requirements.txt 视为“扁平化导出产物”,而非源声明。它不记录依赖来源(是直接安装的?还是子依赖?)、不区分开发/生产环境、无法表达条件依赖(如 platform_system == "Windows"),更不支持可重现的锁机制——你看到的 requests==2.31.0 可能来自不同版本的 setuptools 解析,导致本地与 CI 行为不一致。

  • requirements.txt 是“快照”,不是“合约”
  • 它没有元数据字段(比如作者、分类器、Python 版本约束)
  • 所有依赖都被压平,丢失层级关系,pip install -r requirements.txt 实际执行的是无上下文的线性安装

替代方案:pyproject.toml + 依赖锁文件(如 requirements.lock 或 poetry.lock)

现在标准做法是用 pyproject.toml 声明项目元信息和直接依赖,再由工具生成带哈希、平台、Python 版本标记的锁文件。这解决了 requirements.txt 的核心缺陷:不可重现、不可追溯、不可分组。

  • 使用 pip-tools:写 pyproject.tomlrequirements.in,运行 pip-compile --resolver=backtracking 生成带哈希的 requirements.txt(注意:这只是兼容层,实际应叫 requirements.lock
  • 使用 poetrypyproject.toml 中写 [tool.poetry.dependencies],运行 poetry lock 生成 poetry.lock
  • 使用 uvuv pip compile pyproject.toml -o requirements.lock,速度更快,解析更严格

迁移时最容易踩的三个坑

很多团队在“把旧 requirements.txt 搬进 pyproject.toml”时掉进细节陷阱:

MemFree
MemFree

MemFree - 来自知识库和互联网的混合AI搜索,更快获取准确答案

下载
  • 直接复制粘贴版本号到 [project.dependencies],却没处理 -e .git+https://... 这类 VCS 依赖——它们必须改写成 PEP 508 格式,例如:"mylib @ git+<a href="https://www.php.cn/link/60d179bc263ce0fe8e342c2ea1e67fe6">https://www.php.cn/link/60d179bc263ce0fe8e342c2ea1e67fe6</a>"
  • 忽略 python 字段约束:[project.requires-python] = ">=3.9" 缺失会导致不同环境中解析出不同依赖树
  • dev-requirements.txt 简单合并进主依赖——应该用 [project.optional-dependencies](如 dev = ["pytest", "black"]),再通过 pip install ".[dev]" 安装

CI/CD 和容器镜像里怎么安全用新流程

Dockerfile 或 GitHub Actions 里继续写 pip install -r requirements.txt 是倒退。正确路径是:

立即学习Python免费学习笔记(深入)”;

  • 构建阶段用 uv syncpoetry install --no-dev,它会读取锁文件并跳过解析
  • 不再 COPY requirements.txt .,而是 COPY pyproject.toml poetry.lock .(或 requirements.lock
  • 若必须保留 requirements.txt 名称(比如某些平台强制要求),就把它当成锁文件别名,但内容必须带哈希、来源注释,并禁止手动编辑

真正难的不是换工具,是让所有人理解:依赖声明和依赖锁定必须分离,且锁定必须包含足够上下文。否则只是把 requirements.txt 换个名字,问题还在。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

351

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

427

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

789

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

362

2025.07.23

pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

351

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

427

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

789

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

362

2025.07.23

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1127

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号