首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
如何搭建Python项目自动化打包流程_配置Setuptools与PyProject

如何搭建Python项目自动化打包流程_配置Setuptools与PyProject

热心网友
89
转载
2026-05-06

PyProject.toml:现代Python项目打包配置的核心指南

如何搭建Python项目自动化打包流程_配置Setuptools与PyProject

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

在Python的打包与分发领域,pyproject.toml 文件已成为无可争议的现代标准配置方案。整个Python打包生态系统,包括主流的 setuptools 构建工具,都已全面转向并推荐使用此文件。如果你仍在直接编写和维护传统的 setup.py 脚本,需要特别注意——这种模式不仅已经过时,而且在 pip ≥23.1 及最新版 build 工具中,很可能会触发弃用警告,甚至直接导致项目构建失败。

第一步:在 pyproject.toml 中声明构建后端

许多开发者在第一步就遇到阻碍:执行 python -m build 命令时,系统报错 ModuleNotFoundError: No module named 'setuptools.build_meta',或提示“未指定构建后端”。其根本原因在于缺少了关键的 [build-system] 配置段落。

  • 必须在 [build-system] 段落中,明确声明 build-backend = "setuptools.build_meta"
  • requires 列表里必须至少包含 "setuptools>=61.0"(此版本开始完整支持PEP 621标准)和 "wheel"(用于生成标准的 .whl 二进制分发包)。
  • 若计划采用 setuptools_scm 工具来自动化管理项目版本号,则需在 requires 列表中额外添加 "setuptools-scm[toml]>=8.0"
[build-system]
requires = ["setuptools>=61.0", "wheel"]
build-backend = "setuptools.build_meta"

第二步:采用PEP 621标准配置项目元数据(完全替代setup.py)

现在,你不再需要编写 setup.pysetup.cfg 文件。所有项目核心信息都应统一写入 [project] 段落,这是 setuptools 61.0 及以上版本原生支持的现代化配置方式。

  • name(包名)、version(版本)、description(描述)、readme(自述文件)、requires-python(Python版本要求)是必须填写的核心字段。
  • dependencies 字段替代了旧的 install_requires,其格式为字符串列表,并完整支持PEP 508依赖规范(例如条件依赖:"requests>=2.25; platform_system != 'Windows'")。
  • optional-dependencies 对应原有的 extras_require,用于定义可选依赖组。键名即为 extra 的名称(如 devtest),值是对应的依赖包列表。
  • 一个关键细节:如果你打算使用 setuptools_scm 自动从 __version__ 变量或 Git 标签提取版本号,则必须删除 [project] 中的 version 字段,否则两者会发生冲突。
[project]
name = "mylib"
version = "0.1.0"
description = "A sample package"
readme = "README.md"
requires-python = ">=3.8"
dependencies = ["requests>=2.25"]

[project.optional-dependencies]
dev = ["pytest>=7.0", "black"]

第三步:配置动态版本管理(setuptools_scm 使用详解)

手动维护 version 字段极易出错且繁琐。setuptools_scm 能够基于 Git 提交历史或标签自动生成语义化版本号,极大提升效率,但其配置有一些特定要求,忽略则可能导致功能失效。

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

  • 首先,确保项目根目录是一个有效的 Git 仓库(包含 .git/ 目录),并且至少存在一个符合语义化版本规范的标签(例如 v0.1.01.2.3)。
  • [build-system]requires 列表中加入 "setuptools-scm[toml]>=8.0"
  • 务必删除 [project] 段落中的 version 字段,这是激活 setuptools_scm 自动版本管理功能的前提条件。
  • 如需自定义版本生成行为,可添加 [tool.setuptools_scm] 配置段落。例如,设置回退版本:fallback_version = "0.0.0";或禁用本地版本节点:local_scheme = "no-local-version"

执行打包命令与常见问题解决方案

运行 python -m build 命令,默认会同时生成源码分发包(sdist,格式为 .tar.gz)和二进制分发包(wheel,格式为 .whl)。但在实际的持续集成与部署流程中,我们往往需要精确控制输出类型,或跳过某些步骤。

  • 仅构建 wheel 包:python -m build --wheel;仅构建源码包:python -m build --sdist
  • 若遇到报错 error: invalid command 'bdist_wheel',这通常意味着 wheel 包未被正确添加到 build-system.requires 依赖列表中。
  • 打包完成后,强烈建议使用 twine check dist/* 命令检查生成分发包的元数据是否符合 PyPI 规范。注意,并非所有警告都需要处理,但像 InvalidDistribution 这类错误必须修复后才能上传。
  • 在将包上传至 PyPI 之前,务必确认 project.urls(项目链接)、project.authors(作者信息)等字段均已完整填写。缺少必要描述或作者信息的包会被 PyPI 仓库直接拒绝上传。

最后,分享两个最容易被开发者忽略的关键陷阱。首先是 Git 仓库状态:setuptools_scm 默认要求工作目录是干净的(即没有未提交的更改),否则它可能会静默地回退到配置的 fallback_version。你需要在 [tool.setuptools_scm] 中显式设置 dirty = true 来允许“脏”提交状态下的版本生成。其次,文件位置至关重要:pyproject.toml 必须放置在项目的根目录下,并且确保它没有被 MANIFEST.in 文件排除(当然,在现代的 PEP 621 配置范式下,大多数项目已不再需要手动编写 MANIFEST.in 文件)。

来源:https://www.php.cn/faq/2319656.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

Python怎么将多个特征处理步骤组合_FeatureUnion合并多种提取器
编程语言
Python怎么将多个特征处理步骤组合_FeatureUnion合并多种提取器

Python怎么将多个特征处理步骤组合_FeatureUnion合并多种提取器 FeatureUnion 在 scikit-learn 中早已被弃用 先说一个明确的结论:FeatureUnion 这个工具,从 scikit-learn 1 2 版本开始就被官方标记为弃用(deprecated)了。如

热心网友
05.06
Python如何监听全局键盘按键实现自动化快捷键触发
编程语言
Python如何监听全局键盘按键实现自动化快捷键触发

Python如何监听全局键盘按键实现自动化快捷键触发 你是否希望在Python中设置一个全局快捷键?例如,无论你当前正在编辑文档、浏览网页还是运行游戏,只需按下Ctrl+Shift+X这样的组合键,就能自动执行预设的自动化任务。这个需求听起来直观,但在实际开发中,会面临跨平台兼容性、系统权限以及逻辑

热心网友
05.06
Python如何统计分组内不重复的元素个数_聚合时指定nunique统计函数
编程语言
Python如何统计分组内不重复的元素个数_聚合时指定nunique统计函数

Python分组去重计数:掌握nunique()函数,提升数据分析效率 在数据分析工作中,按组统计唯一值数量是一项常见且关键的任务。例如,分析每个产品类别下的独立访客数,或计算每个销售区域每年上架的不同商品种类。此时,pandas库中的nunique()函数便成为高效解决此类问题的首选工具。 nun

热心网友
05.06
Python自动化识别验证码图片_tesseract-ocr实现OCR识别
编程语言
Python自动化识别验证码图片_tesseract-ocr实现OCR识别

Tesseract OCR 识别失败的核心原因在于输入图像质量不佳且缺乏针对性预处理。必须进行二值化、形态学去噪、倾斜校正等操作,并配合使用 --psm 8 参数和字符白名单;通过 Python 调用时需显式传递配置参数,在 Windows 系统上还需指定 tesseract_cmd 路径;调试过程

热心网友
05.06
Python怎么销毁一个对象_探究__del__析构函数与垃圾回收机制
编程语言
Python怎么销毁一个对象_探究__del__析构函数与垃圾回收机制

Python对象销毁机制详解:__del__析构函数与垃圾回收的正确使用 Python中__del__方法的局限性:为何它不是可靠的销毁钩子 需要明确的是,Python的__del__方法**无法保证一定会被执行**,因此不适合用于释放文件句柄、网络连接或数据库事务等关键系统资源。它仅仅是CPyth

热心网友
05.06

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

荣耀400pro关机要按几秒
电脑教程
荣耀400pro关机要按几秒

荣耀400 Pro正确关机全指南:从常规操作到故障应对详解 需要关闭您的荣耀400 Pro手机?日常操作其实非常简便。只需长按位于机身右侧的电源键约3秒钟,屏幕上便会浮现一个简洁的半透明菜单,其中明确列出了“关机”、“重启”以及“紧急呼叫”选项。直接点击“关机”,系统将启动一次10秒的安全倒计时,随

热心网友
05.06
红米K30Pro如何拆后盖胶怎么清理
电脑教程
红米K30Pro如何拆后盖胶怎么清理

红米K30 Pro后盖拆解教程:专业工具与细致手法的完美结合 红米K30 Pro的后盖采用了高强度背胶配合隐藏式螺丝的双重固定设计,想要实现无损拆解,绝非依靠蛮力可以完成。整个操作流程对加热温度、撬启手法以及清洁标准都有严格要求,任何环节的疏忽都可能导致部件损伤。具体而言,其后盖边缘使用了耐高温的工

热心网友
05.06
三星zflip电池百分比需要root吗
电脑教程
三星zflip电池百分比需要root吗

无需Root权限:三星Galaxy Z Flip系列电量数字显示设置全解析 很多三星折叠屏手机用户都想知道,如何在状态栏直接查看精确的电池百分比数字,是否必须获取Root权限才能实现?实际上完全不需要。三星自Galaxy Z Flip 5、Z Flip 4等主流机型开始,已在系统层面内置了这一实用功

热心网友
05.06
笔记本开机自检时能看到DDR3或DDR4吗
电脑教程
笔记本开机自检时能看到DDR3或DDR4吗

笔记本开机自检信息虽不直接标注“DDR3”或“DDR4”,但联想、戴尔、华硕等品牌BIOS画面常以“PC3-”或“PC4-”编码间接揭示内存代际。UEFI自检显示的内存频率(如2400MHz 3200MHz)结合JEDEC规范可辅助推断:PC3对应DDR3,PC4对应DDR4。更高精度的识别方案包括

热心网友
05.06
空调制冷但不太凉是压缩机问题吗?
电脑教程
空调制冷但不太凉是压缩机问题吗?

空调制冷不足怎么办?先别急着维修压缩机,这些问题更常见 夏天开空调却感觉不够凉爽?很多朋友的第一反应是压缩机坏了,其实压缩机故障的概率相对较低。根据维修行业的大数据统计,绝大多数制冷效果不佳的情况,源于几个容易被忽略的日常维护与环境因素。滤网积尘、制冷剂泄漏、外机散热不良才是真正的高发原因。盲目更换

热心网友
05.06