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

Setting working directory of a converted .py file to .exe file(将转换后的.py文件的工作目录设置为.exe文件)

本文介绍了将转换后的.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现在将是脚本或可执行文件的目录。然后,您可以将其用作访问其他文件的基础。

这篇关于将转换后的.py文件的工作目录设置为.exe文件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

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

基础教程推荐