Vscode 中 python模块的导入问题

查看当前Python解释器的模块搜索路径

复制代码

|---|----------------------------|
| | import sys |
| | paths = sys.path |
| | # 遍历当前Python解释器的模块搜索路径列表 |
| | for path in paths: |
| | print(path) |

终端输出信息:

复制代码

|---|-------------------------------------------------------------------------------------------------------------------|
| | (base) PS E:\Projects\OCR-sdk> (D:\ProgramData\Anaconda3\shell\condabin\conda-hook.ps1) ; (conda activate base) |
| | (base) PS E:\Projects\OCR-sdk> & D:\ProgramData\Anaconda3\python.exe e:/Projects/OCR-sdk/tests/path.py |
| | e:\Projects\OCR-sdk\tests |
| | D:\ProgramData\Anaconda3\python313.zip |
| | D:\ProgramData\Anaconda3\DLLs |
| | D:\ProgramData\Anaconda3\Lib |
| | D:\ProgramData\Anaconda3 |
| | D:\ProgramData\Anaconda3\Lib\site-packages |
| | D:\ProgramData\Anaconda3\Lib\site-packages\win32 |
| | D:\ProgramData\Anaconda3\Lib\site-packages\win32\lib |
| | D:\ProgramData\Anaconda3\Lib\site-packages\Pythonwin |
| | (base) PS E:\Projects\OCR-sdk> |

路径仅包含当前python文件、系统环境变量和当前python环境目录,当前项目根目录不在Python的模块搜索路径中时,所以跨目录的模块导入会失败。

解决方法

通过配置VSCode的集成终端环境变量,将项目根目录添加到PYTHONPATH中,让Python解释器能够正确找到项目中的所有模块。

配置步骤

修改用户配置,通过ctrl+shift+p 打开用户配置文件:

也可以修改当前项目的工作区配置文件\.vscode\settings.json

在配置文件中添加如下配置:

复制代码

|---|----------------------------------------|
| | { |
| | "terminal.integrated.env.windows": { |
| | // 设置 PYTHONPATH 环境变量为当前工作区根目录 |
| | "PYTHONPATH": "${workspaceFolder}" |
| | } |
| | } |

配置说明

  • terminal.integrated.env.windows:针对Windows系统的集成终端环境变量配置
  • PYTHONPATH:Python解释器用于搜索模块的环境变量
  • ${workspaceFolder}:VSCode内置变量,表示当前工作区的根目录路径

其他平台配置

windows/Linux/macOS配置

复制代码

|---|----------------------------------------|
| | { |
| | "terminal.integrated.env.windows": { |
| | "PYTHONPATH": "${workspaceFolder}" |
| | }, |
| | "terminal.integrated.env.linux": { |
| | "PYTHONPATH": "${workspaceFolder}" |
| | }, |
| | "terminal.integrated.env.osx": { |
| | "PYTHONPATH": "${workspaceFolder}" |
| | } |
| | } |

验证配置是否生效

再次查看模块搜索路径

复制代码

|---|----------------------|
| | ```````python```` |
| | import sys |
| | paths = sys.path |
| | for path in paths: |
| | print |

为了防止修改后未立即生效,可以在新终端里再次测试或者直接重启Vscode

复制代码

|---|----------------------------------------------------------------------------------------------------------|
| | (base) PS E:\Projects\OCR-sdk> & D:\ProgramData\Anaconda3\python.exe e:/Projects/OCR-sdk/tests/path.py |
| | e:\Projects\OCR-sdk\tests |
| | E:\Projects\OCR-sdk |
| | D:\ProgramData\Anaconda3\python313.zip |
| | D:\ProgramData\Anaconda3\DLLs |
| | D:\ProgramData\Anaconda3\Lib |
| | D:\ProgramData\Anaconda3 |
| | D:\ProgramData\Anaconda3\Lib\site-packages |
| | D:\ProgramData\Anaconda3\Lib\site-packages\win32 |
| | D:\ProgramData\Anaconda3\Lib\site-packages\win32\lib |
| | D:\ProgramData\Anaconda3\Lib\site-packages\Pythonwin |

如果配置成功,那么项目根目录(例如:E:\Projects\OCR-sdk)应该出现在sys.path的输出中。

注意

  1. 重启终端:修改配置后需要重新打开集成终端才能生效
  2. 多项目支持 :每个项目可以有独立的.vscode/settings.json配置
  3. 路径分隔符 :在Windows中使用分号;分隔多个路径,在macOS/Linux中使用冒号:

扩展配置

如果需要添加多个路径到PYTHONPATH

复制代码

|---|--------------------------------------------------------------------------------------|
| | { |
| | "terminal.integrated.env.windows": { |
| | "PYTHONPATH": "${workspaceFolder};${workspaceFolder}\\src;${workspaceFolder}\\lib" |
| | } |
| | } |

相关推荐
alwaysrun8 分钟前
Python自动提取邮件订阅链接并解析
python·url·邮件·ai提取
何中应8 分钟前
Conda安装&使用
python·conda·python3.11
无敌昊哥战神18 分钟前
【LeetCode 37】解数独 (Sudoku Solver) —— 回溯法详解 (Python/C/C++)
c语言·c++·python·算法·leetcode
风流 少年24 分钟前
Python Web框架:FastAPI
前端·python·fastapi
生而为虫32 分钟前
在VScode中使用Claude Code agent并配置模型(仅mac电脑实际操作,windows电脑未实际操作如有问题可留言)
windows·vscode·macos
Qres82135 分钟前
Rabrg/artificial-life test
python·模拟
财经资讯数据_灵砚智能42 分钟前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月1日
大数据·人工智能·python·信息可视化·自然语言处理
好奇龙猫1 小时前
[大学院ーpython-base learning3: python and recommendation system ]
开发语言·python
篮子里的玫瑰1 小时前
Python与网络爬虫——字典与集合
开发语言·python
skilllite作者1 小时前
Zed 1.0 编辑器深度评测与实战指南
开发语言·人工智能·windows·python·编辑器·agi