python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python包发布到PyPI

Python包发布到PyPI的实现步骤

作者:Redmi人儿

本文主要介绍了Python包发布到PyPI的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

本文将详细介绍如何使用 pyproject.toml 配置将 Python 包发布到 PyPI,包括完整的配置示例、构建命令和故障排除方法。

📦 项目配置

基础 pyproject.toml 配置

[build-system]
requires = ["setuptools>=61.0", "wheel"]
build-backend = "setuptools.build_meta"

[project]
name = "your-package-name"
version = "0.1.0"
authors = [
    {name = "Your Name", email = "you@example.com"}
]
description = "A short description of your package"
readme = {file = "README.md", content-type = "text/markdown"}
license = {text = "MIT"}
classifiers = [
    "Programming Language :: Python :: 3",
    "License :: OSI Approved :: MIT License",
    "Operating System :: OS Independent",
]
requires-python = ">=3.7"
dependencies = [
    "click>=8.1",
]

[project.urls]
Homepage = "https://github.com/yourusername/your-package"

[project.scripts]
your-command = "your_package.module:main"

[tool.setuptools]
packages = {find = {}}

完整配置说明

关键字段说明:

包名约定:

🛠️ 工具安装

# 安装构建和上传工具
pip install --upgrade build twine setuptools wheel

# 验证安装
python -m build --version
twine --version

🔨 构建流程

1. 清理构建环境

# 清理旧的构建文件
rm -rf dist/ build/ *.egg-info/

2. 构建包

# 构建源码包和 wheel 包
python -m build

# 构建结果
ls dist/
# your-package-name-0.1.0.tar.gz
# your-package-name-0.1.0-py3-none-any.whl

3. 验证包

# 检查元数据
twine check dist/*

# 查看包内容
unzip -l dist/*.whl | head -10

🚀 发布到 PyPI

1. 准备 PyPI 账号

2. 上传包

# 上传到正式 PyPI
twine upload dist/*

# 使用 API Token 认证
# 用户名: __token__
# 密码: pypi-xxxxxxxxxxxxxxxxxxxx

3. 测试安装

# 验证发布成功
pip install your-package-name

🧪 测试环境发布

推荐先在 TestPyPI 测试:

# 注册 TestPyPI 账号
# 访问 https://test.pypi.org

# 上传到测试环境
twine upload --repository-url https://test.pypi.org/legacy/ dist/*

# 从测试环境安装
pip install --index-url https://test.pypi.org/simple/ your-package-name

🐛 常见问题解决

1. 元数据缺失错误

ERROR: InvalidDistribution: Metadata is missing required fields: Name, Version

解决方案:

# 升级 twine 到最新版本
pip install --upgrade twine

# 使用模块方式运行
python -m twine check dist/*

2. 包名冲突

HTTPError: 400 Client Error: The name 'your-package' is already in use

解决方案:

3. 版本冲突

HTTPError: 400 Client Error: File already exists

解决方案:

📋 发布检查清单

🔄 版本管理最佳实践

  1. 语义化版本控制:

    • 主版本.次版本.修订版本
    • 不兼容的 API 修改:主版本号递增
    • 向下兼容的功能性新增:次版本号递增
    • 向下兼容的问题修正:修订版本号递增
  2. 发布流程:

    # 1. 更新版本号
    # 编辑 pyproject.toml: version = "0.1.1"
    
    # 2. 提交更改
    git add pyproject.toml
    git commit -m "Bump version to 0.1.1"
    git tag v0.1.1
    
    # 3. 构建和发布
    rm -rf dist/ build/ *.egg-info/
    python -m build
    twine upload dist/*
    

💡 高级配置

包含数据文件

[tool.setuptools]
include-package-data = true

[tool.setuptools.package-data]
"your_package.data" = ["*.json", "*.txt"]

可选依赖项

[project.optional-dependencies]
dev = ["pytest>=6.0", "black"]
gui = ["tkinter", "pyqt5"]

多平台脚本

[project.scripts]
my-cli = "my_package:main"

[project.gui-scripts]
my-gui = "my_package.gui:main"

🌟 总结

通过本指南,你可以:

发布后,用户可以通过 pip install your-package-name 安装你的包,让你的代码为社区所用!

本文基于实际项目经验整理,适用于 Python 3.7+ 和现代打包工具链。到此这篇关于Python包发布到PyPI的实现步骤的文章就介绍到这了,更多相关Python包发布到PyPI内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文