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

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


一、为什么选择 .whl 文件

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

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

二、项目结构准备

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

text 复制代码
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. 安装打包工具

bash 复制代码
pip install build wheel setuptools

2. 配置 pyproject.toml

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 文件

在项目根目录执行:

bash 复制代码
python -m build

生成结果在 dist/ 目录:

text 复制代码
dist/
├── mypkg-0.1.0-py3-none-any.whl
└── mypkg-0.1.0.tar.gz

4. 本地安装测试

bash 复制代码
pip install dist/mypkg-0.1.0-py3-none-any.whl

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

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

python 复制代码
# setup.py
from setuptools import setup, find_packages

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

构建:

bash 复制代码
python setup.py bdist_wheel

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


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

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

方案 1:Cython 编译

text 复制代码
.py → .pyx → .so / .pyd → 打包成 whl

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

方案 2:PyArmor 混淆

bash 复制代码
pip install pyarmor
pyarmor gen mypkg/

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


六、总结

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

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

相关推荐
luobinrobin1 分钟前
射频测试带界面
python
曹轲恒2 分钟前
SpringBoot配置文件(1)
java·spring boot·后端
a努力。4 分钟前
中国电网Java面试被问:RPC序列化的协议升级和向后兼容
java·开发语言·elasticsearch·面试·职场和发展·rpc·jenkins
码农水水11 分钟前
得物Java面试被问:大规模数据的分布式排序和聚合
java·开发语言·spring boot·分布式·面试·php·wpf
不脱发的程序猿15 分钟前
使用Python高效对比多个相似的CAN DBC数据
python·单片机·嵌入式硬件·嵌入式
winfredzhang20 分钟前
构建自动化 Node.js 项目管理工具:从文件夹监控到一键联动运行
chrome·python·sqlite·node.js·端口·运行js
AI_567824 分钟前
Airflow“3分钟上手”教程:用Python定义定时数据清洗任务
开发语言·人工智能·python
小北方城市网30 分钟前
SpringBoot 安全认证实战(Spring Security + JWT):打造无状态安全接口体系
数据库·spring boot·后端·安全·spring·mybatis·restful
Aurora-Borealis.34 分钟前
Day 38 GPU训练和call方法
python
Ulyanov34 分钟前
PyVista三维战场仿真实战
开发语言·python·tkinter·pyvista·gui开发