将转换后的.py文件的工作目录设置为.exe文件

问题描述

转换后的.exe文件出现问题。它找不到我的Excel文件。

我有以下代码

import pandas as pd
import os

abspath = os.path.abspath(__file__)
dname = os.path.dirname(abspath)
os.chdir(dname)

#Load data
data = pd.read_excel("data.xlsx")
...
代码的第二部分(abspath、DNAME、os.chdir(DNAME))是将路径设置为.py文件的位置。因此,将.py文件和.xlsx文件放在一起将始终使其在任何位置都能找到它。

然后我使用

将其转换为.exe
pyinstaller --hidden-import=pandas --onefile script.py

若要使script.py正常工作,我必须将data.xlsx文件与script.py文件放在同一文件夹中。

我假设将.exe文件从dir文件夹拖到.xlsx文件所在的位置会使其运行,但运行.exe文件会返回以下错误:

无法执行脚本脚本。目录中没有这样的文件"data.xlsx"。

无论".exe+.xlsx"文件夹在什么位置,如何才能使其读取我的Excel文件?


解决方案

您遇到的问题是,当您运行可执行文件时,文件被解压缩到临时目录并从那里运行。这意味着i)当前/Working目录是临时目录,ii)实际执行的程序的位置也是该临时目录,因此获取路径的两种方式都不会执行您想要的操作。

但是,当作为可执行文件运行时,可以通过sys模块获得一些附加值。在本例中有用的是sys.frozensys.executable,前者设置为True,后者设置为用户运行的可执行文件的位置。

过去我通过以下方式找到了需要的路径:

if getattr(sys, 'frozen', False):
    app_path = os.path.dirname(sys.executable)
else:
    app_path = os.path.dirname(os.path.abspath(__file__))

其中app_path现在将是脚本或可执行文件的目录。然后,您可以将其用作访问其他文件的基础。

相关文章