python打包exe,打包好后,启动exe报错找不到paddleocr

本文介绍了如何使用PyInstaller工具对包含PaddleOCR的脚本进行打包,包括安装步骤、生成.spce文件、配置资源和解决启动exe后报错的方法,重点在于解决图片找不到的问题和配置.pycache路径。

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

目录

1、安装pyinstaller

2、生成脚本文件的.spce文件

 3、资源文件配置

4、生成exe文件

5、使用了paddleocr启动exe后报错

6、配置.spce文件

7、重新生成exe文件

8、关于图片找不到的问题


参考:PaddleOCR打包exe--Pyinstaller_paddleocr 打包exe_mjiansun的博客-优快云博客

 打包好后启动exe报错如图所示:

从头开始讲起。

1、安装pyinstaller

打包需要使用到pyinstaller,需要用pip安装

pip install pyinstaller

2、生成脚本文件的.spce文件

安装好以后,在cmd窗口输入以下命令,生成脚本文件的.spce文件

pyi-makespec script.py

生成后可以看到.py文件同目录下存在一个同名的.spce文件,双击打开后可以看到内容如下:

 

参数的含义如下:

Analysis主要接收一系列的脚本名作为输入,它会分析所有导入的模块以及其他依赖等。Analysis类中的pathex定义了打包的主目录,对于在此目录下的py文件可以只写文件名不写路径。

PYZ会生成所有相关pyz文件并进行归档,最终会打包进可执行文件中

EXE会在分析好的脚本以及pyz文件基础上生成可执行文件。其中,Console=False代表程序运行时不带CMD窗口。

COLLECT文件夹模式下,COLLECT会创建用于存放各文件的文件夹。而单文件模式下,COLLECT不会被用到,EXE会直接接收所有的脚本,模块以及二进制文件。所以,如果是-F参数(单文件)生成的spec文件是不会有这个类的。

Analysis.datas这可以设置在打包后的程序中添加资源文件。比如:datas=[(‘./a.txt’, ‘.’),(‘./b.jpg’, ‘.’)],这个就是将打包时工作目录中的a.txt文件和b.jpg作为资源文件,最后复制到打包后的目录下。如果还有其它资源文件,则继续添加元组。

Analysis. hiddenimports这个可以设置打包程序时要导入的库的名称。如:hiddenimports=[‘pandas’, ‘numpy’]

Analysis. excludes:这个可以设置打包程序时不要导入的库的名称。如:excludes=[‘pandas’, ‘numpy’]

EXE. exclude_binaries设置打包模式,True:文件夹模式;False:单文件模式。

EXE.upx设置是否使用upx压缩。

EXE.upx_excludeupx压缩时跳过压缩项。比如upx_exclude =[‘vcruntime140.dll’] 则代表压缩时不压缩vcruntime140.dll动态库。

EXE.console设置是否在运行程序时显示cmd窗口。True代表显示,False代表不显示。建议第一次打包时带上。如果运行出现什么问题,可以在cmd窗口中显示。

EXE. icon设置程序的图标。

 3、资源文件配置

如果没有使用到图片资源等,就可以直接使用命令生成exe了,如果使用了图片资源则在.spce的datas=[]中添加资源文件名字。在这里,我使用了一个文件夹存放使用到的所有图片,就可以这样写:

datas=[('res','res')],

4、生成exe文件

在cmd中输入以下命令,等待一段时间看到输出的成功完成就可以了

pyinstaller script.spec

打包好后会生成两个文件夹,分别是build和dist,exe就在dist里面,build可以直接删除我们使用不到。

进入dist可以看到以下文件,“_internal”就是打包好所需的环境:

启动.exe就可以使用了

5、使用了paddleocr启动exe后报错

如果在脚本中使用了paddleocr启动exe后可能会报错,需要配置.spce配置文件如图所示:

 

6、配置.spce文件

在pathex和binaries中填写虚拟环境或者其他python路径下的paddleocr与paddle\\libs:

pathex=['xxxx\\Python\\Python39\\Lib\\site-packages\\paddleocr',	' xxxx \Python\\Python39\\Lib\\site-packages\\paddle\\libs'],
binaries=[('xxxx\\Python\\Python39\\Lib\\site-packages\\paddleocr','.'),	('xxxx\\Python\\Python39\\Lib\\site-packages\\paddle\\libs','.')],

7、重新生成exe文件

保存后再执行pyinstaller script.spec,双击exe就可以正常运行了。

下面是我的脚本:

8、关于图片找不到的问题

使用的图片可能找不到,其实图片已经打包到_internal文件夹下了,把exe文件放到_internal文件下,或把资源文件夹放到与exe同级就可以了,如图:

<think>好的,我现在需要帮助用户解决PyInstaller打包后生成的EXE文件运行报错的问题。首先,我要回顾一下用户提供的引用内容,看看有什么线索。用户引用了三个资料,其中提到了在Win7系统下运行报错打包Tkinter程序的问题以及处理运行环境的目录问题。用户的需求是到解决方案,所以需要综合这些信息。 首先,我应该考虑常见的原因。比如,缺失依赖文件,特别是动态链接库或数据文件。比如,用户可能在代码中用了相对路径,但打包后路径改变导致不到文件。另外,第三方库如PaddleOCR可能有隐藏的依赖项,PyInstaller无法自动捕捉到。 接下来,用户提到在Win7报错,而打包环境是Win10。这可能涉及到系统兼容性问题,比如某些库在Win7下不可用,或者VC运行库版本问题。需要检查目标系统是否安装了必要的运行库。 然后,关于Tkinter的问题,引用2中提到打包Tkinter程序时的报错,可能需要添加数据文件或检查是否有资源文件未正确打包。比如,Tkinter的图标或其他资源文件可能需要手动添加。 引用3中提到的解决方案涉及修改代码,检测运行环境是否为打包后的EXE,并调整路径。这提示在处理路径时,需要动态判断是否在打包环境中,从而正确设置文件路径。 现在,我需要将这些信息整理成步骤。首先,检查依赖是否完整,使用--hidden-import添加缺失的模块。然后,处理数据文件,使用--add-data选项。接着,检查路径问题,确保代码中使用sys._MEIPASS来正确引用资源。此外,考虑系统兼容性,安装VC运行库和检查Python版本。还有,用工具如Dependency Walker分析依赖,或者使用控制台查看详细错误信息。 可能还需要分情况讨论,比如控制台报错、闪退、特定库的问题等。比如,如果用户用了PaddleOCR,需要手动添加资源文件;如果是Tkinter,要确保图标等文件被打包。同时,建议用户测试不同Windows版本,更新PyInstaller等。 最后,需要确保回答结构清晰,分点列出解决方案,并引用提供的资料作为支持。还要生成相关问题,如如何添加隐藏导入、处理路径问题、特定库的打包方法等。</think>### PyInstaller打包EXE运行报错解决方案 #### 一、基础排查步骤 1. **获取完整错误信息** 运行EXE时添加`--debug all`参数生成调试日志: ```bash pyinstaller --debug all your_script.py ``` 或通过命令行启动EXE查看控制台报错信息(适用于非闪退情况)。 2. **检查系统环境兼容性** - Windows 7需安装[VC++ 2015-2022运行库](https://aka.ms/vs/17/release/vc_redist.x64.exe)[^1] - 确认Python版本与目标系统架构一致(32位/64位) - 使用`sys.version`打印运行时Python版本,验证是否与打包环境一致 #### 二、依赖缺失处理 $$ \text{总依赖} = \text{显式导入} + \text{隐式依赖} + \text{数据文件} $$ 1. **添加隐藏导入** 对动态导入的模块(如插件系统、延迟加载库)使用: ```bash pyinstaller --hidden-import=module_name your_script.py ``` 2. **处理特殊库依赖**(以PaddleOCR为例) ```python # 在代码中添加环境检测 if getattr(sys, 'frozen', False): base_path = sys._MEIPASS ocr_config_path = os.path.join(base_path, 'paddleocr', 'config') ``` 打包命令添加资源: ```bash pyinstaller --add-data "venv/Lib/site-packages/paddleocr/*.yml;./paddleocr/" your_script.py ``` #### 三、路径问题修复 1. **资源路径标准化方案** ```python def resource_path(relative_path): if hasattr(sys, '_MEIPASS'): return os.path.join(sys._MEIPASS, relative_path) return os.path.join(os.path.abspath("."), relative_path) icon_path = resource_path('app_icon.ico') ``` 2. **配置文件加载示例** ```python config_path = resource_path('config/settings.cfg') with open(config_path, 'r') as f: config = json.load(f) ``` #### 四、高级调试技巧 1. **依赖树分析工具** 使用`pipdeptree`生成依赖图谱: ```bash pip install pipdeptree pipdeptree --packages=your_package > dependencies.txt ``` 2. **二进制文件检查** 通过Dependency Walker分析EXE的DLL依赖: ```bash # 使用前需要下载depends22_x64.zip depends.exe your_executable.exe ``` #### 五、典型错误处理表 | 错误现象 | 解决方案 | |---------|----------| | `Failed to execute script` | 添加`--log-level DEBUG`参数获取堆栈跟踪 | | 闪退无提示 | 通过`try...except`包裹main函数捕获异常 | | 第三方库报错 | 使用`--paths`指定库路径:`--paths=/your/custom/path` | | 防病毒软件拦截 | 添加数字签名或加入杀软白名单 |
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值