解决使用 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, 下班!

相关推荐
沛沛rh451 小时前
React 学习笔记:State、hook —— 组件的记忆
前端·javascript·react.js
0和1的舞者8 小时前
Spring AOP详解(一)
java·开发语言·前端·spring·aop·面向切面
web小白成长日记9 小时前
在Vue样式中使用JavaScript 变量(CSS 变量注入)
前端·javascript·css·vue.js
QT 小鲜肉9 小时前
【Linux命令大全】001.文件管理之which命令(实操篇)
linux·运维·服务器·前端·chrome·笔记
C_心欲无痕9 小时前
react - useImperativeHandle让子组件“暴露方法”给父组件调用
前端·javascript·react.js
BullSmall11 小时前
支持离线配置修改及删除操作的实现方案
前端
全栈前端老曹11 小时前
【前端路由】Vue Router 嵌套路由 - 配置父子级路由、命名视图、动态路径匹配
前端·javascript·vue.js·node.js·ecmascript·vue-router·前端路由
EndingCoder11 小时前
安装和设置 TypeScript 开发环境
前端·javascript·typescript
张雨zy12 小时前
Vue 项目管理数据时,Cookie、Pinia 和 LocalStorage 三种常见的工具的选择
前端·javascript·vue.js
五月君_12 小时前
Nuxt UI v4.3 发布:原生 AI 富文本编辑器来了,Vue 生态又添一员猛将!
前端·javascript·vue.js·人工智能·ui