第一次使用pyinstaller打包pycharm写的一个多文件项目,遇到了些问题。
使用pyinstaller 3.6 + python 3.7.5 + PyQt5 5.12.0, win10环境。
1. spec文件配置
将自己写的py文件路径写入spec的Analysis中,资源文件原始路径以及打包后路径作为二元元组写入datas中。
2. pyinstaller打包
```
pyinstaller -D -w 我的文件(main.spec)
```
3. lib not found处理
打包时出现warning,且打包后的exe无法运行。
实际上这可能是2个问题,warning不一定会影响exe程序运行。
```
14298 WARNING: lib not found: Qt5MultimediaQuick.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\qml\QtMultimedia\declarative_multim
edia.dll
14875 WARNING: lib not found: Qt5MultimediaQuick.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\qml\~tmultimedia\declarative_multim
edia.dll
15367 WARNING: lib not found: api-ms-win-core-winrt-l1-1-0.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\plugins\position\qtpositi
on_winrt.dll
15371 WARNING: lib not found: api-ms-win-core-winrt-string-l1-1-0.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\plugins\position\q
tposition_winrt.dll
16122 WARNING: lib not found: api-ms-win-core-winrt-l1-1-0.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\plugins\audio\qtaudio_was
api.dll
16132 WARNING: lib not found: api-ms-win-core-winrt-string-l1-1-0.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\plugins\audio\qtau
dio_wasapi.dll
16470 WARNING: lib not found: LIBPQ.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\plugins\sqldrivers\qsqlpsql.dll
18782 WARNING: lib not found: api-ms-win-core-winrt-l1-1-0.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\bin\Qt5Bluetooth.dll
18788 WARNING: lib not found: api-ms-win-core-winrt-string-l1-1-0.dll dependency of C:\Users\Robin\AppData\Roaming\Python\Python37\site-packages\PyQt5\Qt\bin\Qt5Bluetooth.d
ll
```
总结起来,就是缺少4个dll文件:
Qt5MultimediaQuick.dll
api-ms-win-core-winrt-l1-1-0.dll
api-ms-win-core-winrt-string-l1-1-0.dll
LIBPQ.dll
查看网上各种调试方法,小结如下:
1,将C:\Windows\System32\downlevel等添加到环境变量;
2,切换到win7环境下打包;
3,切换32位python文件;
4,下载2G大小的SDK
检查缺失的api-ms-win-core-winrt-l1-1-0.dll等文件并不在C:\Windows\System32\downlevel中存在,因此方法1添加环境变量不能解决这一dll文件的缺失。
方法2,太麻烦没试。
方法3,看到有说直接写一个hello world,用pyinstaller打包,若成功则跟32或64版本无关。测试了下可以正常打包,忽略。
方法4,下载总是弹出错误。
最后解决方案是,将缺失的dll文件找到对应32/64版本,下载到相应位置上去。
最终依然有LIBPQ.dll的报警,且build下的warn文件里也有一些missing module named XXX的报警,但写了一个简单的import PyQt5, 添加几个可见widget作为测试程序打包,可以正常运行。
因此排除掉dll文件缺失问题以及PyQt库的问题,不用理会那些报警(但如果是自己写的模块和py文件报警则需要检查)。
Failed to Execute Script XXX
最后的exe文件依然无法执行。逐个文件打包测试,最后发现根本原因是其中一个文件调用的ini文件路径有问题,导致执行失败。
我所写的py文件与ini文件位置是同一个父文件下的不同子文件中,pycharm中测试正常。而打包后,ini文件ini文件作为资源文件,重新移动到打包后的文件的ini文件夹中,spec的datas设置为
```
datas=[('D:\\OneDrive\\Python Program\\Info System\\ini\\', 'ini')]
```
执行exe无法执行,可能因为pyinstaller将所有spec中Analysis下的py文件都打包到exe所在文件夹,因此再将ini文件放到该文件夹内,则相对关系和pycharm中写的代码不一样,从而找不到ini文件导致出错。
最终解决办法是直接再将ini文件夹直接移动到和exe文件夹的上一级文件(dist文件夹)中,问题解决。