将转换后的.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文件放在一起将始终使其在任何位置都能找到它。
然后我使用
将其转换为.exepyinstaller --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.frozen
和sys.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
现在将是脚本或可执行文件的目录。然后,您可以将其用作访问其他文件的基础。
相关文章