商城首页欢迎来到中国正版软件门户

您的位置:首页 >将Python开发的Window应用打包成exe的流程步骤

将Python开发的Window应用打包成exe的流程步骤

  发布于2026-05-20 阅读(0)

扫一扫,手机访问

步骤1:使用PyInstaller打包Python应用

想把你的Python应用变成Windows上双击就能运行的.exe文件?第一步,离不开PyInstaller这个得力工具。

将Python开发的Window应用打包成exe的流程步骤

安装PyInstaller

打开你的命令行工具,一条简单的pip命令就能搞定:

pip install pyinstaller

打包应用为目录结构

接下来是关键的一步。为了让最终的程序能顺利运行,你得确保所有依赖的文件,比如数据、配置文件或者工具脚本,都被打包进去。这时候,--add-data参数就派上用场了。

pyinstaller --windowed --add-data "data/*;data" --add-data "tools/*;tools" --add-data "*.pdf;." main.py

这里有几个参数需要留意:

  • --windowed:如果你打包的是图形界面应用,加上这个参数,运行时就不会弹出那个黑乎乎的控制台窗口了。
  • --add-data “源路径;目标路径”:这个参数的作用是把指定的文件或文件夹“搬”到打包后的目录里。分号前面是开发环境中的路径,分号后面是打包后文件在程序目录中的相对位置。

验证输出

命令执行成功后,你会发现在项目目录下多了一个dist文件夹。进去找到dist/main/目录,这里就躺着打包好的main.exe以及你添加的所有文件。先别急着高兴,双击运行一下,看看程序是否能正常启动,功能是否完整。

步骤2:使用Inno Setup创建安装程序

打包好的目录虽然能运行,但直接发给用户显然不够专业。一个标准的Windows安装程序,能选择安装路径、创建快捷方式,体验才好。这就轮到Inno Setup出场了。

下载并安装Inno Setup

首先,去它的官网下载安装包。这是个免费且功能强大的安装程序制作工具。

  • 官网:https://jrsoftware.org/isdl.php

编写安装脚本(.iss文件)

Inno Setup通过一个后缀为.iss的脚本文件来定义安装行为。你可以用任何文本编辑器创建它,内容大致如下:

[Setup]
AppName=MyApp
AppVersion=1.0
DefaultDirName={autopf}MyApp
DefaultGroupName=MyApp
OutputDir=.Output
OutputBaseFilename=MyApp_Setup
Compression=lzma
SolidCompression=yes

[Files]
Source: "distmain*"; DestDir: "{app}"; Flags: ignoreversion recursesubdirs createallsubdirs

[Icons]
Name: "{group}MyApp"; Filename: "{app}main.exe"
Name: "{commondesktop}MyApp"; Filename: "{app}main.exe"

这个脚本结构很清晰:

  • [Setup]:配置安装程序的基本信息,比如应用叫什么、版本号是多少、默认安装到哪里。
  • [Files]:告诉安装程序需要复制哪些文件。这里指向了我们之前用PyInstaller生成的dist/main目录。
  • [Icons]:定义在开始菜单和桌面上创建哪些快捷方式,方便用户启动。

编译脚本生成安装程序

打开Inno Setup,加载你写好的.iss脚本文件,然后点击菜单栏的 Build > Compile。稍等片刻,一个名为MyApp_Setup.exe的专业安装包就生成在脚本指定的Output目录里了。

步骤3:处理文件路径问题

到了这一步,有个隐蔽的“坑”必须填上。在开发时,我们通常用相对路径(比如‘data/config.ini’)来访问资源文件。但程序被打包后,文件的实际位置变了,再用原来的路径就找不到了,会导致程序报错。

解决办法是,在代码里动态地判断当前运行环境,从而获取正确的资源路径。下面这个函数是行业内的通用解决方案:

import sys
import os

def get_resource_path(relative_path):
    # 判断是否处于PyInstaller打包后的环境
    if getattr(sys, 'frozen', False):
        # 如果是,资源在PyInstaller创建的临时目录中
        base_path = sys._MEIPASS
    else:
        # 如果不是,就是开发环境,资源在当前脚本所在目录
        base_path = os.path.dirname(os.path.abspath(__file__))
    # 拼接并返回绝对路径
    return os.path.join(base_path, relative_path)

# 使用示例:这样无论在开发还是打包后,都能找到配置文件
config_path = get_resource_path(os.path.join('data', 'config.ini'))

把这个函数集成到你的代码中,所有文件访问都通过它来转换路径,兼容性问题就迎刃而解了。

步骤4:测试安装程序

生成安装包只是成功了一半,严格的测试必不可少。建议你按照以下步骤完整走一遍:

  1. 在另一台干净的电脑上(或虚拟机里)运行生成的MyApp_Setup.exe,尝试安装到不同的目录,比如默认的Program Files和自定义的D盘
  2. 安装完成后,去安装目录里仔细核对,看看所有必要的文件(主程序、数据文件夹、工具等)是否都齐全地躺在那里。
  3. 最后,双击桌面或开始菜单的快捷方式启动应用,把核心功能全部测试一遍,确保一切运转如常。

可选优化

如果你的应用有更复杂的需求,还可以考虑下面这些优化点,让安装包更加完善:

  • 依赖检测:有些应用依赖特定的运行环境,比如VC++ Redistributable。你可以在Inno Setup脚本里加入检测逻辑,如果用户电脑上没有,就自动引导安装。
  • 文件权限:对于那些需要被用户修改的配置文件,最好不要放在Program Files这种受保护的系统目录。更常见的做法是,程序首次运行时,将配置文件复制到%APPDATA%这样的用户数据目录。
  • 版本更新:当你要发布新版本时,可以在Inno Setup脚本中编写卸载旧版本的逻辑,实现平滑升级。

最终结果

遵循以上步骤,你最终交付给用户的,不再是一个需要解释如何运行的文件夹,而是一个标准的Windows安装程序(.exe文件)。用户只需双击,跟随指引选择安装路径,完成后桌面上就会出现快捷方式。所有依赖的文件都已被自动部署到正确的位置,用户体验与专业的商业软件无异。

本文转载于:https://www.jb51.net/python/364126irz.htm 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注