Python 打包成 EXE 完整教程(单文件 \+ 整个工程)

我给你一套最简单、最通用、零报错 的打包方案,用 PyInstaller (Python 最主流、最稳定的打包工具),不管是单个 .py 文件 ,还是整个项目工程(多文件、带图片 / 配置 / 依赖库),都能一键打包成独立 EXE。

全程不用装复杂环境,复制命令就能用!


一、先安装打包工具

打开 CMD / 终端,执行:

bash 复制代码
pip install pyinstaller

二、场景 1:打包 单个 Python 文件

比如你只有一个 main\.py,没有其他依赖文件。

最简命令(生成单个 EXE)

bash 复制代码
pyinstaller -F -w main.py

命令解释

  • \-F:打包成单个独立 EXE 文件(最常用)

  • \-w:运行时不弹出黑色控制台窗口(GUI 程序必加)

  • 如果是命令行工具,去掉 -w

输出位置

打包完成后,去你的项目文件夹里找:

Plain 复制代码
dist/
   main.exe  <-- 这就是最终可直接运行的文件

三、场景 2:打包 整个 Python 工程

多文件项目(比如:main\.pyutils\.pyconfig\.jsonimages/ 文件夹、venv/ 虚拟环境)。

核心命令(推荐)

bash 复制代码
pyinstaller -F -w main.py

PyInstaller 会自动扫描并打包所有导入的模块、依赖文件


四、如果项目里有 外部资源(图片 / 配置 / 模型 / 数据库)

比如:

  • images/logo\.png

  • config\.yaml

  • data/model\.pth

直接打包会找不到文件,必须用 \-\-add\-data 把资源一起打进 EXE。

Windows 命令格式

bash 复制代码
pyinstaller -F -w --add-data "资源路径;目标路径" 主文件.py

示例(打包带图片 + 配置文件)

bash 复制代码
pyinstaller -F -w ^
--add-data "images;images" ^
--add-data "config.yaml;." ^
main.py
  • images;images:把 images 文件夹打包进 EXE,运行时自动释放到同目录 images

  • config\.yaml; \.:把配置文件放到根目录


五、进阶:给 EXE 加 图标

准备一个 \.ico 格式图标(不能是 png/jpg),放在项目目录。

命令:

bash 复制代码
pyinstaller -F -w -i logo.ico main.py

六、最常用的 4 条万能命令(直接复制用)

1. 单文件 + 无控制台(GUI 软件)

bash 复制代码
pyinstaller -F -w main.py

2. 单文件 + 控制台(工具脚本)

bash 复制代码
pyinstaller -F main.py

3. 单文件 + 无控制台 + 图标

bash 复制代码
pyinstaller -F -w -i app.ico main.py

4. 整个工程 + 资源文件 + 图标

bash 复制代码
pyinstaller -F -w -i app.ico --add-data "images;images" --add-data "config.yaml;." main.py

七、打包后常见问题(必看)

  1. EXE 双击打不开 / 一闪而过

    • 大概率是缺资源文件,或代码报错

    • 去掉 -w 用控制台运行,看报错信息

  2. 文件太大(几百 MB) pip install virtualenv virtualenv venv venv\\Scripts\\activate pip install 你的依赖 pip install pyinstaller再打包,体积能缩小到 10~30MB

    • 使用 虚拟环境,只装项目用到的库
  3. 杀毒软件误报

    • PyInstaller 打包的程序普遍会被误报

    • 解决方法:添加信任 / 用 \-\-noupx 命令


八、快速总结

  1. 安装:pip install pyinstaller

  2. 单文件:pyinstaller \-F \-w 文件名\.py

  3. 多文件工程:一样的命令,自动打包依赖

  4. 带资源:加 \-\-add\-data

  5. 输出文件在:dist/xxx\.exe


总结

  • 单个 .py 文件 :用 pyinstaller \-F \-w 文件名\.py

  • 整个工程:同样命令,自动识别多文件

  • 带图片 / 配置 :用 \-\-add\-data 绑定资源

  • 最终 EXE 都在 dist 文件夹里,可直接发给别人运行(无需装 Python)


相关推荐
qq_2949405517 小时前
Python环境搭建
开发语言·python
数据库小学妹17 小时前
分布式数据库架构演进:从集中式到分布式,三大路线一次讲清楚
数据库·分布式·数据库架构
暴躁小师兄数据学院17 小时前
【AI大模型应用开发工程师特训】第01讲—AI在企业中的定位
大数据·python·ai·语言模型
Rauser Mack17 小时前
编程零基础五分钟用AI做了个贪吃蛇(附prompt)
人工智能·python·html·prompt·ai编程
洛水水17 小时前
redis缓存:雪崩、穿透、击穿详解
数据库·redis·缓存
lulu121654407817 小时前
【开发者指南】Gemini 3.5开发入门:从API调用到Agent构建
java·开发语言·人工智能·python·ai编程
沐风。5617 小时前
AI 实战
python
盲敲代码的阿豪17 小时前
Python 爬虫入门基础教程:从入门到实践
开发语言·爬虫·python
暴躁小师兄数据学院17 小时前
【AI大数据工程师特训笔记】第01讲:数据库基本概念
大数据·数据库·笔记