解决VSCode无法识别相对路径的问题

前言:

近日在学习python文件操作时,发现使用VSCode作为编辑器时,文件的相对路径会出问题,报错"指定路径下找不到文件",无法找到想要的文件。

知识点①:不同操作系统所使用的路径斜杠不同:Linux系统是/,Windows系统是\

知识点②:在使用相对路径表示【某源代码文件】所在的位置时,使用 ./ 表示当前所在目录,使用 ../ 表示当前所在目录的父目录。

问题:

这里先贴上笔者使用相对路径的 Python 代码段:

python 复制代码
# 该代码片段位于 draw_chart.py 文件中
chart_title = '1836A'
file_path = f"../pending_files/{chart_title}.xlsx"   # 欲使用相对路径引用 1836A.xlsx 文件

再列出笔者的工程目录树

Python_project

└─ .vscode

│ ├─ launch.json

│ └─ settings.json

├─ app_sample

│ └─ draw_chart.py

├─ pending_files

│ └─ 1836A.xlsx

在基于以上的情况下,出现了相对路径报错的问题。报错提示如下图所示:

🌵 解决方案(一)

修改要点 :将相对路径引用的代码段修改成当前目录引用,即../改成./,如下所示。

python 复制代码
# 该代码片段位于 draw_chart.py 文件中
chart_title = '1836A'
file_path = f"./pending_files/{chart_title}.xlsx"   # 欲使用相对路径引用 1836A.xlsx 文件

修改后可正常运行,问题解决。

修改原理 :因为此时相对路径的【参照位置】,是打开的"工程项目文件夹",不是源代码文件目录所在位置。

以笔者的工程项目Python_project为示例,此时相对路径的【参照位置】是当前目录Python_project文件夹,不是app_sample!!!

则相对路径"./pending_files/{chart_title}.xlsx"等价于

绝对路径"E:/code/Python_project/pending_files/1836A.xlsx"。

🌵 解决方案(二)

修改要点1 :首先我们不修改相对路径的引用,即代码段保持../不变。

python 复制代码
# 该代码片段位于 draw_chart.py 文件中
chart_title = '1836A'
file_path = f"../pending_files/{chart_title}.xlsx"   # 欲使用相对路径引用 1836A.xlsx 文件

修改要点2 :其次使用UI形式设置,依次打开 设置→搜索execute→勾选 Execute in file Dir 选项,如下图所示:

或者使用json文本形式设置,即在settings.json中添加"python.terminal.executeInFileDir": true,,如下图所示:

上述两者效果是一致的,VSCode有UI和json文本两种形式设置,任选一种即可,笔者推荐json文本形式设置。

最后运行Python代码,可以看到正常运行,问题解决。

修改原理 :此时相对路径的【参照位置】,是"当前源代码的文件目录"。

以笔者的工程项目Python_project为示例,此时相对路径的【参照位置】是app_sample

则相对路径".../pending_files/{chart_title}.xlsx"等价于

绝对路径"E:/code/Python_project/pending_files/1836A.xlsx"。

📚参考链接

VScode - 相对路径

[报错] VSCODE无法识别相对路径

绝对路径和相对路径区别详解

什么是相对路径?相对路径的具体写法和用法

Python绝对路径和相对路径详解

相关推荐
iCxhust1 小时前
8086/8088单板机VSCode集中环境开发编译(第二版整理)
ide·vscode·嵌入式硬件·编辑器·嵌入式·微机原理·8086最小系统
努力的小帅1 小时前
使用 Tailscale 实现 Ubuntu 远程开发(VSCode Remote SSH + NoMachine)
linux·ide·vscode·ubuntu·编辑器·copilot
开发者联盟league2 小时前
解决vscode默认终端log日志输出中文乱码的问题
ide·vscode·编辑器
2501_916007472 小时前
XCode 15 IDE新特性:苹果集成开发环境全面升级,提升编程效率与体验
ide·vscode·macos·ios·个人开发·xcode·敏捷流程
贾亚超2 小时前
手动配置vscode-server
ide·vscode·编辑器
lzhdim2 小时前
一款基于 .Net WinForm 开发的节点编辑器,纯 GDI 实现,体积仅 100+Kb
编辑器·.net
61900833617 小时前
win idea 控制台中文乱码
java·ide·intellij-idea
智驾17 小时前
Claude Code + vscode + minimax2.7
vscode·claudecode·minimax2.7
Geoking.19 小时前
VSCode 安装 Claude Code 插件 + ccswitch 配置 DeepSeek API 完整教程(Windows 新手向)
ide·windows·vscode
其实防守也摸鱼20 小时前
VS code怎么使用 Conda 安装预编译包
开发语言·网络·c++·vscode·安全·web安全·conda