当前位置: 代码网 > it编程>前端脚本>Python > Windows下PyInstaller打包Python的完整教程

Windows下PyInstaller打包Python的完整教程

2025年10月22日 Python 我要评论
前言一篇掌握 pyinstaller:从零到可分发的 .exe。覆盖安装、常用参数、资源文件、gui、.spec 进阶、签名与排错。为什么选择 pyinstaller适用:将 python 脚本打包为

前言

一篇掌握 pyinstaller:从零到可分发的 .exe。覆盖安装、常用参数、资源文件、gui、.spec 进阶、签名与排错。

为什么选择 pyinstaller

适用:将 python 脚本打包为无需 python 环境的可执行文件。

优势:自动分析依赖、跨平台(需在目标平台上构建)、支持单文件/目录两种分发方式。

工作原理快览

解析入口脚本的导入依赖,收集 .py、数据文件、动态库。

生成引导器(bootloader)+ 内置 python 解释器 + 资源包。

--onefile:运行时临时解压到缓存目录再执行;--onedir:直接从目录运行。

环境准备(建议使用虚拟环境)

# 1) 新建并激活 venv(powershell)
python -m venv .venv
.\.venv\scripts\activate.ps1
# 2) 升级基本工具
pip install -u pip wheel
# 3) 安装 pyinstaller
pip install -u pyinstaller

快速入门(命令行应用)

示例 app.py

# app.py
import sys, json
from pathlib import path

def resource_path(relative):
    base = getattr(sys, "_meipass", path(__file__).parent)  # onefile 下的临时目录
    return path(base) / relative

def main():
    print("hello pyinstaller!")
    cfg = json.loads(resource_path("data/config.json").read_text(encoding="utf-8"))
    print("config:", cfg)

if __name__ == "__main__":
    main()

准备数据文件:data/config.json

{"app_name":"hello","debug":true}

打包(单文件):

pyinstaller -f -n hello `
  --add-data "data\config.json;data" `
  app.py
  • windows 的 --add-data 使用分号 ;(linux/macos 用冒号 :)。
  • 输出目录:dist/hello.exe(成品)、build/(临时)、hello.spec(构建配置)。

gui 应用打包(隐藏控制台)

  • 控制台程序(默认):--console
  • gui 程序(隐藏控制台):-w--windowed
pyinstaller -f -w -n myapp -i assets\app.ico app.py

资源与路径处理

读取资源时使用上方 resource_path(),兼容开发与打包。

复制资源:

  • 数据:--add-data "src_path;dest_dir"
  • 二进制:--add-binary "src_path;dest_dir"

示例:

pyinstaller -f `
  --add-data "assets\logo.png;assets" `
  --add-binary "bin\helper.dll;bin" `
  app.py

依赖与导入问题

隐式导入未被自动检测:--hidden-import some_pkg.submod

添加搜索路径(非标准包位置):--paths path\to\libs

缩小体积(排除不需要的模块):--exclude-module tests

常用模式与建议

--onefile:易分发;启动需解压,体积更大。

--onedir:启动快;以文件夹分发,便于增量更新。

科学计算(numpy/pandas/scipy)通常推荐 --onedir 以提升启动速度。

.spec 文件进阶(可定制构建)

  • 首次打包会生成 your_app.spec,可编辑以添加资源、修改参数。
  • 使用 .spec 构建:pyinstaller your_app.spec
  • 简例(核心片段,实际文件更长):
# hello.spec(示意)
datas = [("data\\config.json", "data"), ("assets\\logo.png", "assets")]
# 在 analysis(...) 中传入 datas;在 exe(...) 中设置 name、icon、console 等

适合复杂资源收集、多个入口脚本、精细控制压缩/排除。

图标与版本信息(windows)

图标:-i path\to\icon.ico

版本资源:--version-file version_info.txt

version_info.txt 示例(节选):

vsversioninfo(
  fileversion='1.0.0.0',
  productversion='1.0.0.0',
  filedescription='myapp',
  companyname='your company',
)

代码签名与可信度(windows)

  • 未签名的可执行文件更易被杀毒拦截。
  • 使用证书签名(windows sdk 的 signtool):
signtool sign /a /fd sha256 /tr http://timestamp.digicert.com /td sha256 `
  dist\myapp.exe

常见错误排查

“failed to execute script”:从命令行运行 dist\xxx.exe 观察错误;尝试 --log-level debug

启动缓慢(单文件):改用 --onedir 或减少资源体积;可选安装 upx 压缩(可能触发杀毒)。

缺少 dll:确认依赖是否在同目录或通过 --add-binary 复制;必要时在代码中用 os.add_dll_directory() 设置路径(python 3.8+)。

打包前清理缓存:pyinstaller --clean -f app.py

构建与发布建议

固定依赖版本:requirements.txt;在干净环境重装后再打包。

在目标平台上构建(windows 打包 windows,macos 打包 macos)。

小步验证:先 --onedir 验证,再切换 --onefile

ci/cd:在流水线中使用同样的命令和固定版本以保证可重复。

常用命令速查

# 单文件(控制台)
pyinstaller -f -n app app.py
# 单文件(gui,无控制台)
pyinstaller -f -w -n app -i assets\app.ico app.py
# 追加资源/二进制
pyinstaller -f --add-data "data\cfg.json;data" --add-binary "bin\x.dll;bin" app.py
# 指定隐藏导入与路径
pyinstaller -f --hidden-import pkg.sub --paths extra\libs app.py
# 清理并覆盖输出
pyinstaller --clean --noconfirm -f app.py
# 使用 spec 构建
pyinstaller app.spec

到此这篇关于windows下pyinstaller打包python的完整教程的文章就介绍到这了,更多相关pyinstaller打包python内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com