python封装 (pyinstaller)

本文介绍如何将Python程序封装成Windows和Mac OS下的独立可执行文件,包括使用pyinstaller工具的过程、常见问题及解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    windows 下编写控制台程序后,会生成exe的可执行程序,创建工程最后都会生成可执行程序,python工程都是python调用各种模块,执行起来也不方便,所以这里讲一下python封装exe文件过程!

windows 系统(按照我自己环境):

    首先我们拿到python工程文件后,必须保证程序可以正常执行,才能在此环境中进行封装,不然封装成功了,执行时会报错,提示有些模块没有导入

    

    1. 打开cmd 运行 pip install pyinstaller :

    

    2. 安装时,报错,具体就是pywin32版本不对,需要重新安装pywin32:

    

    3. 打开网址 https://www.lfd.uci.edu/~gohlke/pythonlibs/ ,选择pywin32 下载whl文件,注意要和电脑 匹配  
    

    4. 进入下载好的目录下, 运行pip  install  pywin32.whl  

    5. 再次安装pyinstaller,安装成功,准备打包

    

打包:

    1. 确定程序入口(相当于程序的主函数)

    

    2. 通过 cd 命令进入main.py文件所在路径

    

    3. 执行命令: pyinstaller -F -wmain.py --hidden-import=pandas._libs.tslibs.timedeltas可以看到相应目录生成build和dist文件夹  build文件夹没用 可以删除

    

    4. 将platforms文件夹放到exe文件同级目录,运行exe(这里platforms 里面是pyqt调用的动态库文件)

    

    

    5. 打开exe,成功

    


Mac osx系统

PyQT5 封装独立程序,优先推荐 pyinstaller,而非 py2app 或者 py2exe。事实上,PyInstaller 封装 Windows 端的 exe 文件也是不错的选择

这是因为 py2app 等不会将程序环境(如 python 的 frameworks 等),因此并不会封装为一个独立的软件(standalone app),具体表现为仅能在本机正常运行,在别人的电脑上运行会报错。然而 pyinstaller 则封装完整,可在同系统的不同机器上运行。

封装步骤

在 terminal 中依次键入:

pip3 install pyinstaller
pyinstaller --windowed --onefile --clean --noconfirm main.py
pyinstaller --clean --noconfirm --windowed --onefile main.spec

调测

一般而言,很少有同学能一次跑通,经常莫名其妙就闪退了或者报错,非常遗憾大家都得根据本机环境进行一些修改。

那么我们到底要调测哪些东西呢?从哪里看我们的报错呢?

STEP 1: 找到 exec 文件

对于 mac 系统来说,方法有两个(其实本质是一个):

  1. 大家双键单击 app 文件选择 show package contents,如下图找到你们的 exec 文件(文件名字是自己起的,主要看文件类型);
image.png
  1. 直接打开 exec 文件(文件名字是自己起的,主要看文件类型):

    image.png
STEP2: 使用 exec 文件运行,并查看报错
image.png

如上是正确时候的运行输出,但如果有错,这里会有具体的报错信息,每个人可能不同。对应不同的报错信息,大家可以直接复制黏贴到 google 或者 Bing 国际版中查看,建议优先查阅英文网页。

经历过的坑与解决方案

我来列举一下我们团队历经过的坑。

坑1:没选对当前 python 版本

大多数同学的电脑中都不止一个 python 版本,比如 mac 自己本身默认的是 python 2.7。

注意一定要选对 python 的版本,pyinstaller 一定要存在你当前 project 的 interpreter 对应的 python 版本下。

坑2:各工具包版本不适配

你可能有不同的包冲突、不适配,解决的方法也是类似的。

以我经历的坑为例,我电脑的 pandas 版本比较高,在使用 pyinstaller 时报错“Pandas missing pandas._libs.tslibs.timedeltas.so”,导致在程序运行时终端总是报错。

解决的方法是:以 pandas 为例,手动增加 hook 文件,将 pandas 的 hiddenimports(即 Pandas missing pandas._libs.tslibs.timedeltas.so) 写入。其实很简答的,具体如下:。

STEP 1

找到 python frameworks 下 hook 文件所在地

STEP 2

在 hook 文件夹中手动增加 hook-pandas.py 文件,在文件中手动写入:hiddenimports = ["XXXX"],其中 XXX 是指你在运行 exec 文件中报错缺失的那个 module 的名字,对着抄写即可。

比如我的情况为写入:


封装windows时,很顺利,mac系统封装 碰到了各种问题,还是不太了解里面的运行机制,以后再深入了解把!

### 安装 PyInstaller 的方法 在 Python 环境中安装 `PyInstaller` 可以通过多种方式实现,以下是具体的操作说明: #### 方法一:使用 pip 命令安装 如果当前环境已经配置好 `pip` 并连接到互联网,则可以通过以下命令快速完安装: ```bash pip install pyinstaller ``` 此操作会自动下载并安装最新版本的 `PyInstaller` 和其依赖项[^1]。 #### 方法二:手动安装源码包 对于某些特殊场景(如网络受限),可以下载官方发布的源码包进行本地安装。假设已获取到 `PyInstaller-3.4.zip` 文件,解压后进入目录执行如下命令即可完安装: ```bash python setup.py install ``` 该过程适用于离线环境下安装工具的情况[^2]。 #### 方法三:分步安装所需组件 有时为了确保兼容性和稳定性,可能需要单独安装一些必要的模块后再整体部署 `PyInstaller` 。按照顺序需先分别处理以下几个部分: - **基础支持库**:比如 `future`, `pefile`. - **Windows平台特定扩展**:`pypiwin32`. 使用指令为: ```bash pip install pypiwin32 ``` - **MacOS专属需求**: 如果目标操作系统是 macOS, 则额外增加对 `macholib==1.9` 的引入. - 接着再加载其他辅助类库像 `dis3`, `altgraph`. 最后一步才是正式装配主体框架本身即运行下面语句来结束全部准备工作: ```bash pip install pyinstaller==3.4 ``` 验证整个流程无误的方法之一就是尝试调用内置帮助或者查看版本号确认功能可用性: ```bash pyinstaller -v ``` #### 参数简介 当一切就绪之后就可以利用这个强大的封装器把我们的 python 脚本转换独立的应用程序啦! 下面列举几个常用的选项供参考了解下基本语法结构: |参数名 | 描述 | |-- |--| |-h | 显示帮助信息| |-v | 打印版本号| |-D | 创建一个文件夹形式的应用,默认行为| |-F | 将所有资源打包进单个可执行文件| 更多详细的自定义设置可通过查阅官方文档进一步探索[^5]. ```python import sys print(sys.version) ``` 以上就是在不同条件下针对如何正确有效地导入以及初始化 PyInstaller 组件进行了全面阐述.
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值