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

相关推荐
Eiceblue5 小时前
C# 删除 PDF 页面:单页 / 多页批量删除技巧
前端·pdf·c#
悟空瞎说5 小时前
从isMounted到跨页面状态:高级前端如何优雅解决订单场景的“幽灵陷阱”(附React/Vue完整代码)
前端·javascript
C_fashionCat5 小时前
【2026面试题】前端实际场景去考察原理
前端·vue.js·面试
落魄江湖行5 小时前
进阶篇三 Nuxt4 Nitro 引擎:Nuxt 的服务端核心
前端·vue.js·typescript·nuxt4
一壶纱5 小时前
Element Plus 主题构建方案
前端·vue.js
程序员马晓博5 小时前
我的大脑不下班:一个前端工程师的工作反刍自救指南
前端
吴声子夜歌5 小时前
Vue3——表单元素绑定
前端·vue·es6
神の愛5 小时前
js的深拷贝和浅拷贝?啥情况讲解下??底层堆栈空间??object.prototype.toString.call(),还有bind,的具体使用?
前端·javascript·原型模式
浩星5 小时前
「React + Cesium 最佳实践」完整工程化方案
前端·vue.js·react.js
qq_12084093715 小时前
Three.js 模型加载稳定性实战:从资源失败到可用发布的工程化方案
前端·javascript·vue.js·vue3·three.js