本文主要是介绍Bug2:python64位打包程序无法在win7 32位上运行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前言:这篇文章主要记录一下,python打包时出现的坑,这里面主要包含两个坑,按需要查看解决方法,文章的最后是存放两个方法的总体解决方法(可以直接解决两个问题),点击点击跳转
1 项目场景:
1.1 环境需求:
使用当前手头上的电脑环境,进行编译公司的代码。
要求:exe程序可以在windows7 32系统和windows10 32位上可以运行。
当前环境:python3.9-64位,Windows10系统
1.2 初步解决思路:
使用python
的pyinstaller
库对python
代码进行打包。
pyinstaller
安装:在PyCharm
上的解析器上搜索下载pyinstaller
库,或者使用cmd
终端输入pip install pyinstaller
进行安装。
注意:在安装前需要先去查看一下pyinstaller
是否支持你当前的python版本。不过一般情况下都是符合的,除非你使用的python版本很老,然后pyinstaller
版本又很高就会发生不匹配。
2 遇到问题描述:
2.1 问题1:64位python打包的程序无法在32位windows7上运行
在终端上输入打包指令。-D
指打包完成后生一个多文件的exe程序,-i
是添加公司的图标,后面要编译的文件是项目中所有的py
文件。
pyinstaller -D -i 图标文件 要编译的py文件
结果在Windows7 32位上执行弹窗报错:此文件的版本与正在运行的Windows版本不兼容,请检查计算机的系统以了解需要x86(32位)还是x64(64位)版本的程序,然后联系软件发布者。
2.1.1 原因分析:
很显然,在windows7上的弹窗已经告诉我们了,在windows 32位的环境下不支持python 64位编译出来的应用程序。
这其中的原因应该是在于我们python安装的pyinstaller
模块。首先我的python环境是python3.9 64位。那么他打包出来的就是64位的包。这就是为什么64位的exe不能在32位执行的原因。
2.1.2 解决方案:
由于我询问了做C++底层的同事,他们主要的是编译成32位的动态库。再加上我需要运行的系统是win7 32位。所以我索性把我的python3.9 64位直接卸载使用python3.9的32位。
重新打包成新的exe程序。这时window7 32位上就不会报位数不相符的弹窗了。
在此,如果你的电脑是Windows10 64位系统,python32位那么你编译出来的应用程序应该就能在Window10 32位系统上跑了。但是如果你要运行的exe环境是win7 的32位 那么你可能就会遇到下面的问题2。
2.2 问题2:win10打包应用程序在win7运行弹窗报错说缺少api-ms-win-core-path-l1-1-0.dll
解决上面的问题1后,我本以为我在python打包的条路上算是走到头了,结果直接报出这个错误……
报错信息:无法启动此程序,因为计算机中丢失api-ms-win-core-path-l1-1-0.dll。参数重新安装程序已解决此问题。
2.2.1 原因分析
此处再次声明一下问题出现的原因:我使用win10 的python3.9 32位打包后的应用程序放到win7 32位下运行报的错误。
问题原因未知,但是我确定报错问题不是说这台win7 32位的设备缺少api-ms-win-core-path-l1-1-0.dll这个动态库,而是出在python上。
因为我同事也是用win10系统 python 32位打包程序,但是他的应用程序在这个win7 32位上能完美运行。
2.2.2 踩坑经历:
此处主要说一下我踩过的坑,问题2的解决方法点击跳转。
我在网上也查找了相关方案,但是仍然解决不了我的问题……
我先罗列一下我的一些操作,可能发布这些解决方法的博主可以解决他们相关的问题。但是对于我的问题可能不太适用。
2.2.2.1 不适用的解决方法1
单纯看这个报错,应该是我要运行exe的win7 32位电脑上缺少了api-ms-win-core-path-l1-1-0.dll这动态库。
按照提示信息,我下载了api-ms-win-core-path-l1-1-0.dll这个库,然后按照其他博主的方法放到了system32文件夹下。虽然他这个方法解决了弹窗报错,但是我发现我的exe执行会发生闪退问题!exe闪退的可能因素非常多。
我再使用cmd
终端来执行我的exe,这样就能看到执行期间的结果。不过结果报的错误很不友好,甚至在CSDN上都没有相关的解决方法,他的大概意思就是执行exe时发现一个错误的同时又发生其他错误。由于bug特别长我就没有截图。最后由于长时间没有找到解决方法我就放弃了该方法。
2.2.2.1 不适用的解决方法2
我接着从源头上找解决问题的方法,我在pyinstaller
的打包过程中发现,在打包时出现一下几种警告。
WARNING: Hidden import "sip" not found!
WARNING: lib not found: api-ms-win-core-winrt-string-l1-1-0.dll
WARNING: lib not found: api-ms-win-core-winrt-l1-1-0.dll
……
还有很多警告WARNING: lib not found: api-ms-win-core-***-l1-1-0.dll
那就按这些警告一个一个解决。
首先WARNING: Hidden import “sip” not found!是指没有安装隐藏模块sip。可我按照网上很多方法安装,都是安装失败,原因在于我电脑上安装了VS2003,但系统使用VS2003的编译器的时候编译sip模块时出错导致安装不上。
因此我就安装了一个window7 32位的虚拟机想来解决问题安装不了sip库的问题……结果居然解决了win7不能运行的问题了(详细解决方法见下解决方法。后来我发现好像有没有安装sip模块好像都没有问题……
由于在解决sip问题中就解决了win7上不能执行exe问题,所以后续的那些缺少动态库的警告我就没有去管了。网上也有相关处理缺少动态库的方法,虽然没有亲身试验,不过应该可以解决那些警告问题。
2.2.3 解决方法:
- 先安装一个虚拟机VM。然后再去下载win7的镜像文件。这一步骤在网上有很多的参考方法。
- 下载安装python3.7 32位,这里需要和根据你要运行exe的环境看齐,比如你和我一样要在win7 32位下运行python的exe。那么就安装32位的。
- 在win7中安装python程序所需要的各个库,顺便安装个
pyinstaller
库用于打包程序
经过测试,win7下打包的exe可以在win7上跑,也可以在win10上跑,之后,我打包文件都放在这个win7的虚拟机中打包。
但是同事却能在win10上打包,而且可以在win7和win10上跑,相同的方法打包,它可以我却不行,具体解决方法见总体解决方案
注意:win7下只能下载安装python3.9以下(不包含python3.9)的版本。因为python3.9已经不再支持win7了。
总体解决方案
由于在上文中,我虽然解决了win7上运行公司代码的问题。但是总的来说,这并不是从根本上解决问题。我想要解决的是在win10上编译打包,并且满足所有windows系统可使用。
- 安装
Anaconda
32位 https://www.anaconda.com/download/ 这里我是因为我的需要才安装了32位的Anaconda,你可以根据你自己的选择。这里不再有过多的叙述,相关安装教程在其他博主中有更详细的讲解。
- 在
Anaconda
新创建一个python环境,这里我安装的是python3.7
conda create -n python37 python=3.7
这句话的意思是创建一个python3.7的新环境,并且名命为python37。你也可以根据你的需要做更改。-n后面更新环境的名字,python=后面跟python的版本。
如果你忘记环境的名字就在终端中使用
conda env list
来查询以前创建的环境。
这里要注意一下,cmd
终端和Anaconda
的终端是不一样的。cmd
是用于系统所有操作命令的终端,而Anaconda
的终端一般就是为了Anaconda
而设计的。Anaconda
的终端在win10的开始
中打开
Anaconda的终端一打开会有(base)字样在开头如下:
-
切换环境
刚开始的时候,为base环境(默认环境)。
执行activate 环境名 如下即可切换环境(python37是我创建环境的名字):```
activate python37
```
然后再自己新建的环境中安装模块。使用pip install ...
的方法来安装模块。
如果嫌麻烦也可以将这个环境链接到pycharm
中
这里我的pycharm
是2021版本的,其他版本的类似
- 选择
Conda
环境 - 选择现有的编译器
- 找到Anaconda安装路径下的一个文件叫
envs
在里面找到你新建的环境,然后再进去找到python.exe文件。那个Conda可执行文件是默认的不用管。
比如我的就是D:\Users\Administrator\anaconda3\envs\python37\python.exe
选则好解析器后,我们就可以开始安装模块了。然后再pycharm的终端中打包后的exe文件就可以放到win7中运行了。
这篇关于Bug2:python64位打包程序无法在win7 32位上运行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!