Python将源码打包成.whl文件的完整指南

 更新时间:2025年12月30日 08:33:26   作者:程序员爱钓鱼  
Python 项目开发完成后,如何优雅地发布和安装,今天,我们就来详细讲解如何将 Python 源码打包成 .whl 文件(Wheel),并进行安装和分发,希望对大家有所帮助

Python 项目开发完成后,如何优雅地发布和安装?传统的 python setup.py install 虽然可用,但不够现代化,也不方便在不同环境中快速分发。今天,我们就来详细讲解如何将 Python 源码打包成 .whl 文件(Wheel),并进行安装和分发。

一、为什么选择 .whl 文件

.whl 是 Python 官方推荐的二进制分发格式,相比传统的源码安装有几个优势:

  • 快速安装:不需要编译,直接 pip install xxx.whl
  • 跨平台(纯 Python):如果没有 C 扩展,可以在不同操作系统间通用
  • 规范标准:兼容现代 Python 打包工具,如 pipbuild
  • 可控依赖:打包时可以指定依赖,安装时自动拉取

二、项目结构准备

假设你的项目名称是 mypkg,最基础的目录结构如下:

mypkg/
├── mypkg/
│   ├── __init__.py
│   └── core.py
├── README.md
├── setup.py        # 传统方式
└── pyproject.toml  # 现代方式推荐

  • mypkg/:核心代码
  • setup.py:兼容老项目的打包配置
  • pyproject.toml:现代标准的打包配置

三、现代方式:pyproject.toml 打包

Python 官方推荐使用 PEP 517/518 标准,通过 pyproject.toml 来描述构建和依赖信息。

1. 安装打包工具

pip install build wheel setuptools

2. 配置pyproject.toml

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

[project]
name = "mypkg"
version = "0.1.0"
description = "My Python Package"
readme = "README.md"
authors = [
  { name="Your Name", email="you@example.com" }
]
dependencies = []

[tool.setuptools.packages.find]
where = ["."]

3. 构建.whl文件

在项目根目录执行:

python -m build

生成结果在 dist/ 目录:

dist/
├── mypkg-0.1.0-py3-none-any.whl
└── mypkg-0.1.0.tar.gz

4. 本地安装测试

pip install dist/mypkg-0.1.0-py3-none-any.whl

四、传统方式:setup.py打包

对于老项目,如果还在用 setup.py,也可以生成 .whl

# setup.py
from setuptools import setup, find_packages

setup(
    name="mypkg",
    version="0.1.0",
    packages=find_packages(),
    install_requires=[],
)

构建:

python setup.py bdist_wheel

生成的 .whl 文件同样在 dist/ 目录。

五、源码保护与加密(可选)

.whl 文件本质上仍然包含源码,如果想防止直接查看 Python 代码,可以考虑:

方案 1:Cython 编译

.py → .pyx → .so / .pyd → 打包成 whl

适合核心逻辑不想暴露的商业项目。

方案 2:PyArmor 混淆

pip install pyarmor
pyarmor gen mypkg/

可以对源码进行混淆,提高反编译成本。

六、总结

  • .whl 是现代 Python 项目的推荐分发格式
  • 现代方式使用 pyproject.toml + build,简单快捷
  • 传统方式 setup.py 依然可用
  • 可选混淆/编译策略保护核心源码

通过打包成 .whl,你可以方便地分发、安装和管理 Python 项目,让用户体验更流畅,也方便 CI/CD 自动化部署。

到此这篇关于Python将源码打包成.whl文件的完整指南的文章就介绍到这了,更多相关Python源码打包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Tornado服务器中绑定域名、虚拟主机的方法

    Tornado服务器中绑定域名、虚拟主机的方法

    这篇文章主要介绍了Tornado服务器中绑定域名、虚拟主机的方法,本人查看了Tornado才得的方法,特此分享,需要的朋友可以参考下
    2014-08-08
  • windows环境下tensorflow安装过程详解

    windows环境下tensorflow安装过程详解

    这篇文章主要为大家详细介绍了windows环境下tensorflow安装过程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • python中的post请求解读

    python中的post请求解读

    文章介绍了Python中POST请求的4种编码方式:application/x-www-form-urlencoded、multipart/form-data、application/json和text/xml,通过代码示例和工具使用,展示了如何发送和处理这些请求
    2024-11-11
  • pandas中遍历dataframe的每一个元素的实现

    pandas中遍历dataframe的每一个元素的实现

    这篇文章主要介绍了pandas中遍历dataframe的每一个元素的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • python皮尔逊相关性数据分析分析及实例代码

    python皮尔逊相关性数据分析分析及实例代码

    这篇文章主要为大家介绍了python皮尔逊相关性分析及实例代码,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • Python异常处理知识点总结

    Python异常处理知识点总结

    在本篇文章中小编给大家分享了关于Python异常处理的相关知识点以及对应的实例内容,需要的朋友们学习下。
    2019-02-02
  • Python文件如何引入?详解引入Python文件步骤

    Python文件如何引入?详解引入Python文件步骤

    我们整理了一篇关于引入Python文件的一个基础知识点内容,如果你是一个python的学习者,参考一下吧。
    2018-12-12
  • PyCharm代码整体缩进,反向缩进的方法

    PyCharm代码整体缩进,反向缩进的方法

    今天小编就为大家分享一篇PyCharm代码整体缩进,反向缩进的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • 基于hashlib模块--加密(详解)

    基于hashlib模块--加密(详解)

    下面小编就为大家带来一篇基于hashlib模块--加密(详解)。小编觉得挺不错的。现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • python实现腾讯滑块验证码识别

    python实现腾讯滑块验证码识别

    这篇文章主要介绍了python如何实现腾讯滑块验证码识别,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下
    2021-04-04

最新评论