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文件在哪个目录下运行,都能正确找到并写入日志文件,从而避免程序因找不到日志路径而闪退的问题。