当前位置: 首页
编程语言
如何搭建Python项目自动化打包流程_配置Setuptools与PyProject

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

热心网友 时间: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。

同类文章
更多
Go 中测试函数赋值的正确方式:通过接口与类型断言替代函数相等性判断

Go 中测试函数赋值的正确方式:通过接口与类型断言替代函数相等性判断

Go 语言测试函数赋值的正确方法:利用接口与类型断言替代函数相等性比较 由于 Go 语言不支持直接比较函数值,因此无法使用 `p builder == newSDNRequest` 这样的断言。本文将详细介绍一种符合 Go 语言设计哲学的重构方案——将行为差异抽象为接口实现,并通过类型断言在单元测试

时间:2026-05-06 09:24
如何在独立目录中正确加载 Django 模型执行数据库脚本

如何在独立目录中正确加载 Django 模型执行数据库脚本

如何在独立目录中正确加载 Django 模型执行数据库脚本 本文详细讲解如何在 Django 项目外部的独立目录中运行 Python 脚本并成功导入模型,重点解决常见的 ModuleNotFoundError: No module named snippets 错误。通过正确配置 Python

时间:2026-05-06 09:24
c++如何读取波形文件WAV格式_音频头信息解析【进阶】

c++如何读取波形文件WAV格式_音频头信息解析【进阶】

C++如何读取波形文件WA V格式:音频头信息解析进阶指南 处理WA V文件,看似是基础操作,但其中关于字节序、内存对齐和块遍历的细节,却足以让不少开发者踩坑。今天,我们就来深入聊聊,如何安全、准确地解析WA V文件头。 WA V文件头结构怎么解析才不会读错字节顺序 WA V文件本质上是RIFF格式

时间:2026-05-06 09:24
C++ thread_local变量 _ 线程局部存储用法详解【干货】

C++ thread_local变量 _ 线程局部存储用法详解【干货】

C++ thread_local变量:线程局部存储用法详解 要精通C++多线程编程,掌握thread_local关键字是核心环节。它实现了线程局部存储(TLS),为每个线程提供独立的变量副本。深入理解其“首次访问初始化”和“线程隔离”的运行机制,不仅关乎语法正确性,更直接影响程序的性能、资源管理与线

时间:2026-05-06 09:24
C++ std::ranges::views::zip _ C++23多容器并行迭代技巧【详解】

C++ std::ranges::views::zip _ C++23多容器并行迭代技巧【详解】

C++23 std::views::zip:多容器“拉链”迭代详解与避坑指南 首先明确一个核心概念:std::views::zip 并非用于并发或多线程编程,也不提供“并行 for 循环”功能。它的核心作用是将多个容器中的元素按位置一一对应组合,生成一个由 std::tuple 构成的序列,其行为类

时间:2026-05-06 09:23
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程