广告
返回顶部
首页 > 资讯 > 后端开发 > Python >关于pyinstaller生成.exe程序报错:缺少.ini文件的分析
  • 608
分享到

关于pyinstaller生成.exe程序报错:缺少.ini文件的分析

2024-04-02 19:04:59 608人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录生成的.exe文件执行报错测试办法命令行窗口显示报错信息如下新的报错如下上述报错信息解释如下附上pyinstaller的常见参数使用指令:pyinstaller -F -w ma

使用指令:pyinstaller -F -w main.py

生成的.exe文件执行报错

在这里插入图片描述

看报错信息,初步怀疑是生成的.exe不能执行.ini配置文件。

将程序需要的.ini文件放到.exe同级目录下,虽然还是执行不成功,但是没有上述报错了;删除同级目录下面的.ini文件,上述报错仍然存在,说明初步的判定成立,.exe执行不成功与.ini配置文件有关系。

测试办法

pyinstaller不加参数”-F"和“-w",执行执行指令:pyinstaller main.py

加不加“-F"和”-w"效果的详细说明文章链接:https://www.jb51.net/article/183469.htm

在这里插入图片描述

在这里插入图片描述

命令行窗口显示报错信息如下

在这里插入图片描述

dist目录下并没有.ini配置文件,手动添加该文件,再运行main.exe程序,

新的报错如下

在这里插入图片描述

上述报错说模块openpyxl执行load_workbook打开文件功能时报错,但是在PyCharm环境下运行main.py程序是ok的,不明白为什么生成.exe之后就无法打开.xlsx文件。

尝试了好几个.xlsx文件都这样,怀疑是不是生成的.exe不能打开电脑加密的.xlsx文件?

在电脑上新建一个.xlsx文件,不对文件进行任何操作,使其处于未被加密状态,执行.exe程序,和打开加密的.exe文件报错对比如下,发现生成的.exe确实不能打开加密的文件:

在这里插入图片描述

上述报错信息解释如下

最上面的红框框出来的报错是打开的加密文件,可以看出来执行到代码的30行load_workbook打开文件操作;

下面的红框框出来的报错是打开的没有加密文件,可以看出来执行到代码的35行了,这个时候30行的load_workbook打开文件操作执行ok通过了,是其他原因导致的报错;

说明:生成的.exe确实不能打开加密的文件。

将文件解密后,.exe功能执行ok。

同样用解密的文件,使用指令:pyinstaller -F -w main.py 生成的.exe程序,即使放置了需要的.ini配置文件执行结果也不是想要的(只显示一个界面,点击确认button后应该弹出另外一个数据展示界面),但是不会报错。原因未知。

使用"-n"指定生成的.exe的名称,指令:pyinstaller main.py. -n ***

由于.exe实现的界面功能比较简单,没有在程序里面设置日志功能,当遇到操作不当引起bug时还是需要借助命令行窗口的显示查找原因的,所以不使用"-w"参数取消显示命令行窗口了。

附上pyinstaller的常见参数

在这里插入图片描述

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: 关于pyinstaller生成.exe程序报错:缺少.ini文件的分析

本文链接: https://www.lsjlt.com/news/138657.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作