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文件放在一起将始终使其在任何位置都能找到它。
然后我使用
将其转换为.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
现在将是脚本或可执行文件的目录。然后,您可以将其用作访问其他文件的基础。
这篇关于将转换后的.py文件的工作目录设置为.exe文件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:将转换后的.py文件的工作目录设置为.exe文件
基础教程推荐
猜你喜欢
- 使 Python 脚本在 Windows 上运行而不指定“.py";延期 2022-01-01
- 将 YAML 文件转换为 python dict 2022-01-01
- 合并具有多索引的两个数据帧 2022-01-01
- 如何在 Python 中检测文件是否为二进制(非文本)文 2022-01-01
- 哪些 Python 包提供独立的事件系统? 2022-01-01
- Python 的 List 是如何实现的? 2022-01-01
- 如何在Python中绘制多元函数? 2022-01-01
- 症状类型错误:无法确定关系的真值 2022-01-01
- 使用 Google App Engine (Python) 将文件上传到 Google Cloud Storage 2022-01-01
- 使用Python匹配Stata加权xtil命令的确定方法? 2022-01-01