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文件
基础教程推荐
猜你喜欢
- 将 x 轴刻度更改为自定义字符串 2022-01-01
- numpy float:比算术运算中内置的慢 10 倍? 2022-01-01
- 尝试制作WhatsApp机器人 2022-01-01
- 用 Python 编写 Fortran 无格式文件 2022-01-01
- Discord.py 缺少必需的参数 2022-01-01
- 与常规 dict 相比,Python manager.dict() 非常慢 2022-01-01
- 使用生成器和迭代器时 Python 多循环失败 2022-01-01
- pyserial - 可以从线程 a 写入串行端口,是否阻塞从线程 b 读取? 2022-01-01
- 在 Celery 工作人员中捕获 Heroku SIGTERM 以优雅地关 2022-01-01
- 由Python将MP3转换为MIDI(类型错误:无法加载插件:mtg-Melodia:Melodia) 2022-01-01
