Python打包成exe后在不同目录执行闪退的原因是什么?如何解决?

python打包成exe后在不同目录执行闪退问题分析与解决

当我们将python脚本打包成exe文件后,可能会遇到一个棘手的问题:在打包生成的目录中执行exe文件正常,但在将其移动到其他目录执行时,exe文件会闪退且不生成日志文件。这个问题到底是什么原因导致的呢?让我们深入探讨一下这个问题以及解决方案。

问题描述

代码的主要功能是通过定时任务从源数据库中提取数据,然后将其插入到目标数据库中。代码已经在pycharm中成功运行,并能正常打印日志。但是,当使用pyinstaller命令打包成exe文件后,虽然在打包生成的目录中执行正常,但在将其复制到其他目录执行时,exe文件会立即闪退,且不生成任何日志文件。

问题分析

经分析,问题可能出在日志配置上。当exe文件在其生成目录中运行时,日志文件sync22.log可以正常写入。但当exe文件被移动到其他目录时,程序可能无法找到日志文件的路径,从而导致程序在尝试写入日志时崩溃。

解决方案

为了解决这个问题,我们需要修改日志配置,使其能够在任何目录下运行exe文件时都能正确找到日志文件的路径。我们可以通过获取exe文件的当前目录来动态设置日志文件的路径。

以下是解决方案中的关键代码:

立即学习Python免费学习笔记(深入)”;

import os import sys <h1>获取exe所在目录并设置日志路径</h1><p>if getattr(sys, 'frozen', False):</p><h1>打包后的exe路径</h1><pre class="brush:php;toolbar:false">exe_dir = os.path.dirname(sys.executable)

else:

脚本运行路径

exe_dir = os.path.dirname(os.path.abspath(__file__))

os.makedirs(exe_dir, exist_ok=True) log_path = os.path.join(exe_dir, ‘sync22.log’)

日志配置

Logging.basicConfig( filename=log_path, level=logging.INFO, format=’%(asctime)s – %(levelname)s – %(message)s’ )

通过这段代码,我们确保无论exe文件在哪个目录下运行,都能正确找到并写入日志文件,从而避免程序因找不到日志路径而闪退的问题。

Python打包成exe后在不同目录执行闪退的原因是什么?如何解决?

© 版权声明
THE END
喜欢就支持一下吧
点赞13 分享