pyinstaller打包报错RecursionError

本文介绍在使用PyInstaller将Python项目打包成exe时遇到的RecursionError问题及其解决方案。通过修改生成的.spec文件中的递归深度限制,可以有效避免打包过程中的异常,确保打包任务顺利完成。

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

RecursionError
想使用python打包生成exe文件,突然发现在打包过程中会出现:RecursionError: maximum recursion depth exceeded异常,然而百度好久,都在说明一个问题:报错提示超过最大递归深度,解决办法:

import sys

sys.setrecursionlimit(1000000) #例如这里设置为一百万

但是打包命令Pyinstaller -F XXX.py ,该在哪里加这部分代码并没有提及,通过大量查找终于发现了解决pyinstaller打包过程中出现该类异常解决的办法:

执行pyinstaller -F XXX.py 它会在你的目录文件生成XXX.spec文件,然后报错,出现该类异常。
打开XXX.spec文件,在开头添加上面两行代码。
继续执行打包,但是还文件名:pyinstaller -F XXX.spec ,执行该文件,不然前面功夫白费了。
然后应该就会打包成功。

发生此类异常原因:python默认的递归深度是很有限的(默认是1000),因此当递归深度超过999的样子,就会引发这样的一个异常,而在打包过程中引入的包递归深度可能比默认深度大,因此会引发异常。

### PyInstaller 打包时常见错误及解决方案 #### 1. 库版本不兼容引发的错误 当使用 PyInstaller 进行打包操作时,可能会遭遇由库版本差异引起的莫名错误。尝试更新或回滚某些依赖库到特定版本可以有效解决问题[^1]。 ```bash pip install --upgrade pyinstaller pip install package_name==specific_version ``` #### 2. 数据文件收集失败 如果项目中包含了额外的数据文件,在打包过程中这些资源未能被正确识别并加入最终可执行文件内,则可能导致运行时报错。通过自定义钩子函数来显式指定所需数据文件路径能够规避此类情况发生[^2]。 ```python from PyInstaller.utils.hooks import collect_data_files datas = collect_data_files('your_package') ``` #### 3. Qt 平台插件加载失败 (针对 PyQt 或 PySide 用户) 对于基于Qt框架开发的应用程序来说,“无法找到或加载Windows平台插件”的提示往往意味着缺少必要的动态链接库(.dll)文件或者是环境变量配置不当所致。确保安装目录下存在完整的qt.conf配置以及相应的platforms子文件夹,并将其绝对路径添加至系统的PATH环境中即可恢复正常工作状态[^3]。 ```ini [Paths] Prefix=. Plugins=plugins Imports=imports Qml2Imports=qml ``` #### 4. Python 解析器内部异常 部分情况下,由于操作系统特性或是Python解释器本身的局限性,可能会触发底层解析逻辑中的Bug进而造成整个构建流程中断。此时建议检查是否有已知的相关issue记录于官方仓库之中;另外也可以考虑切换不同的Python发行版试试看能否绕过该问题[^4]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值