解决使用 Pyinstaller 打包成可执行文件之后报找不到文件的问题(路径问题)

今天在把一些功能性脚本打包成可执行文件时候遇到了一个找不到文件的问题

举个栗子

创建一个名为 Test 的文件, 代码很简单, 获取当前工作目录

js 复制代码
work_path = os.getcwd()  
print(f'\n\n当前工作路径: {work_path}\n\n')

创建一个 Test 文件夹, 放进去, 跑一下

不负众望, 艰难的跑起来了:

用 pyinstaller 打包一下, 最终在 dist 文件目录下生成一个可执行文件:

双坤一下:

工作目录变成了根目录,这是为什么呢?

由于我不是专业的, 只是个业余写一写简单的用用, 网上查了一下, 似懂非懂的了解了一些,在运行可执行文件时候系统会生成一个临时文件夹, 除代码之外的数据资源需要通过访问临时文件夹获取, 也就是说这个时候的工作目录需要切换到可执行文件所在的目录, 所以解决方案就是切换目录, 写一个方法来获取工作目录(以下代码来自网上):

lua 复制代码
def current_work_path():  
   if hasattr(sys, 'frozen'):  
      return os.path.dirname(sys.executable)           
   return os.path.dirname(__file__)

so, 最终结合 demo 测试一下

lua 复制代码
def current_work_path():  
    if hasattr(sys, 'frozen'):  
        return os.path.dirname(sys.executable)  
    return os.path.dirname(__file__)  
  
work_path = current_work_path()  
os.chdir(work_path)  
print(f'\n\n当前工作路径: {os.getcwd()}\n\n')

这样在执行可执行文件时候就可以访问可执行文件所在目录下的资源了

OK, 下班!

相关推荐
也无晴也无风雨1 小时前
深入剖析输入URL按下回车,浏览器做了什么
前端·后端·计算机网络
Martin -Tang2 小时前
Vue 3 中,ref 和 reactive的区别
前端·javascript·vue.js
FakeOccupational3 小时前
nodejs 020: React语法规则 props和state
前端·javascript·react.js
放逐者-保持本心,方可放逐3 小时前
react 组件应用
开发语言·前端·javascript·react.js·前端框架
曹天骄4 小时前
next中服务端组件共享接口数据
前端·javascript·react.js
阮少年、5 小时前
java后台生成模拟聊天截图并返回给前端
java·开发语言·前端
郝晨妤6 小时前
鸿蒙ArkTS和TS有什么区别?
前端·javascript·typescript·鸿蒙
AvatarGiser6 小时前
《ElementPlus 与 ElementUI 差异集合》Icon 图标 More 差异说明
前端·vue.js·elementui
喝旺仔la7 小时前
vue的样式知识点
前端·javascript·vue.js
别忘了微笑_cuicui7 小时前
elementUI中2个日期组件实现开始时间、结束时间(禁用日期面板、控制开始时间不能超过结束时间的时分秒)实现方案
前端·javascript·elementui