vscode 使用python虚拟环境,配置 fastapi 开发

本文介绍了如何在计算机上安装Python和VSCode,然后通过创建虚拟环境、安装FastAPI和Uvicorn来设置FastAPI的开发环境。详细步骤包括激活虚拟环境、安装所需库以及在VSCode中配置运行和调试环境。此外,还解决了Windows执行策略问题,以便顺利运行应用程序。

首先,您需要在您的计算机上安装 Python 和 VS Code。

然后,您可以按照以下步骤设置 FastAPI 开发环境:

  1. 创建一个新项目,并配置Python 虚拟环境:
mkdir fastapi_prj
cd fastapi_prj
python -m venv myenv

其中 myenv 是您想要使用的虚拟环境名称。

  1. 激活虚拟环境:

在 Windows 上:

myenv/Scripts/activate.bat

在 Linux 或 macOS 上:

source myenv/bin/activate

以下各步骤windows和Linux大同小异,各位看官可以根据自己环境稍加变化即可,我就不区分来写了。

  1. 在虚拟环境中安装 FastAPI:
pip install fastapi
  1. 安装 Uvicorn 服务器:
pip install uvicorn

第3步和第4步,可以合并成一条语句:

pip install "fastapi[all]"
  1. 在 VS Code 中打开项目文件夹,并创建一个新的 Python 文件。

在项目文件夹中开启VS Code,例如:

(myenv) D:\workspace\fastapi_prj>code .

信任文件夹和文件
在这里插入图片描述
目录下创建一个main.py文件

  1. 在新文件中添加以下代码:
from fastapi import FastAPI

app = FastAPI()

@app.get("/")
async def root():
    return {"message": "Hello World"}

这是一个最基本的 FastAPI 应用程序,它将创建一个名为 app 的 FastAPI 实例,并在根路径上添加一个 GET 路由。

在VS Code中类似于这样:
在这里插入图片描述
6. 配置运行环境
在VS Code中,按CTRL+SHIFT+P,选择,python select Interpreter,如下图
在这里插入图片描述
选择当前项目虚拟环境下的运行环境,如下图,如果没有,那么跳过下图,往下看
在这里插入图片描述
如果没有上述的虚拟环境,那么我们就新建一个:
选择+Enter interpreter path,填写虚拟环境的python执行文件
在这里插入图片描述
或者 直接用浏览的方式选择
在这里插入图片描述

  1. 配置运行文件:
    点击左侧:Run and Debug按钮,点击:create a launch.json file.
    在这里插入图片描述
    点击后,选择FastAPI,如果没有,那么直接选第一个Python File
    在这里插入图片描述
    会生成并打开一个launch.json文件,确认文件内容如下:
{
    // Use IntelliSense to learn about possible attributes.
    // Hover to view descriptions of existing attributes.
    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Python: FastAPI",
            "type": "python",
            "request": "launch",
            "module": "uvicorn",
            "args": [
                "main:app"
            ],
            "jinja": true,
            "justMyCode": true
        }
    ]
}
  1. 运行
    点击运行按钮,运行程序:
    在这里插入图片描述
    如果是在windows上运行,不出意外的话,肯定会出意外类似就是这样:
PS D:\workspace\fastapi_prj> & d:/workspace/fastapi_prj/myenv/Scripts/Activate.ps1
d:/workspace/fastapi_prj/myenv/Scripts/Activate : 无法加载文件 d:/workspace/fastapi_prj/myenv/Scripts/Activate.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。
所在位置 行:1 字符: 1
+  d:/workspace/fastapi_prj/myenv/Scripts/activate
+ ~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : SecurityError: (:) [],PSSecurityException
    + FullyQualifiedErrorId : UnauthorizedAccess

解决办法:
用管理员身份,打开一个powershell,输入如下命令:Set-ExecutionPolicy RemoteSigned

Windows PowerShell
版权所有 (C) Microsoft Corporation。保留所有权利。

尝试新的跨平台 PowerShell https://aka.ms/pscore6

PS C:\Windows\system32>  Set-ExecutionPolicy RemoteSigned

执行策略更改
执行策略可帮助你防止执行不信任的脚本。更改执行策略可能会产生安全风险,如 https:/go.microsoft.com/fwlink/?LinkID=135170
中的 about_Execution_Policies 帮助主题所述。是否要更改执行策略?
[Y](Y)  [A] 全是(A)  [N](N)  [L] 全否(L)  [S] 暂停(S)  [?] 帮助 (默认值为“N”): A

重新运行,如下图,正常:
在这里插入图片描述

  1. 在浏览器中访问 http://localhost:8000/,您应该能够看到 “Hello World” 消息。

  2. 现在您可以使用 VS Code 中的调试器和其他工具来开发您的 FastAPI 应用程序。

附:
通过运行以下命令启动应用程序(在虚拟环境中):

(myenv) D:\workspace\fastapi_prj>myenv\Scripts\uvicorn.exe main:app --reload

其中 main 是您的 Python 文件名,app 是您在第 6 步中创建的 FastAPI 实例名。

### 如何在 VSCode配置 Python 环境用于 FastAPI 开发 #### 安装必要的扩展 为了更好地支持 PythonFastAPI开发,在 Visual Studio Code (VSC) 中应安装特定的扩展来提升编码体验。推荐安装如下两个主要插件: - **Python 插件**:此插件提供了对 Python 语言的支持,包括 IntelliSense、linting、调试等功能[^2]。 ```json { "recommendations": [ "ms-python.python" ] } ``` - **Pylance**:这是一个强大的语言服务器,能够显著提高代码补全的速度和准确性,增强开发者编写高效代码的能力。 ```json { "recommendations": [ "ms-python.vscode-pylance" ] } ``` #### 创建并激活虚拟环境 对于任何基于 Python 的项目来说,使用独立的虚拟环境是非常重要的做法之一。可以利用 `venv` 或者其他类似的工具如 `conda` 来创建一个新的虚拟环境[^1]。 ```bash # 使用 venv 创建名为 'fastapi_env' 的新虚拟环境 python -m venv fastapi_env # 激活该虚拟环境(Windows) .\fastapi_env\Scripts\activate.bat # 激活该虚拟环境(macOS/Linux) source fastapi_env/bin/activate ``` 一旦激活了新的虚拟环境,则可以在其中安全地安装所需的依赖项而不会影响全局 Python 设置。 #### 安装 FastAPI 和 Uvicorn 接下来需要安装 FastAPI 库及其 ASGI 服务器 uvicorn,以便运行应用程序实例。 ```bash pip install fastapi[all] pip install "uvicorn[standard]" ``` 上述命令会下载并安装最新版本的 FastAPI API 框架及相关组件,同时也设置了默认的异步 HTTP 服务器——Uvicorn。 #### 调试配置 为了让调试更加方便快捷,应该设置好 VSC 内建调试器的相关参数。可以通过 `.vscode/launch.json` 文件来进行具体设定。 ```json { "version": "0.2.0", "configurations": [ { "name": "Run FastAPI App", "type": "python", "request": "launch", "program": "${workspaceFolder}/main.py", // 主文件路径 "args": ["--reload"], // 自动重启选项 "jinja": true, "console": "integratedTerminal", "justMyCode": false // 是否只跟踪用户代码 } ] } ``` 以上 JSON 片段定义了一个启动配置,它允许一键执行带有热重载特性的 FastAPI 应用程序,并且可以选择性开启或关闭仅限于个人编写的源码追踪模式。 #### 推荐的项目结构 构建一个清晰合理的目录布局有助于维护项目的可读性和模块化程度。下面给出了一种可能适用的 FastAPI 项目基本框架: ``` my_fastapi_project/ │── .gitignore # Git忽略列表 │── main.py # 启动入口脚本 │── app/ │ ├── __init__.py # 初始化包标志 │ ├── routers/ # 存放路由处理函数 │ └── items.py │ ├── models/ # 数据模型类定义 │ └── item_model.py │ ├── dependencies/ # 外部服务接口封装 │ └── database.py └── tests/ # 测试套件所在位置 ``` 这种分层设计使得不同职责的功能被合理分离出来,便于后续迭代升级时定位修改点。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值