FastAPI 入门教学

liftword2个月前 (01-07)技术文章22

FastAPI 入门教学

在当今快速迭代的软件开发环境中,选择一个高效且易用的框架至关重要。Python 的 FastAPI 正是这样一个集速度与灵活性于一身的现代化 Web 框架。本文将带你初步了解 FastAPI 的基本用法,并通过一些实例加深理解。

一、安装 FastAPI

首先,确保你已经安装了 Python 和 pip。然后,通过以下命令安装 FastAPI 及其依赖的 Uvicorn 服务器:

pip install fastapi uvicorn

二、创建第一个 API

接下来,创建一个简单的 FastAPI 应用。新建一个 Python 文件,比如 main.py,并编写以下代码:

from fastapi import FastAPI

app = FastAPI()

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

这段代码定义了一个简单的 API,当访问根路径 / 时,返回 JSON 格式的数据。

三、运行服务器

使用 Uvicorn 运行这个 FastAPI 应用:

uvicorn main:app --reload

--reload 参数表示在代码更改时自动重新加载服务器,方便开发调试。

四、访问 API

打开浏览器或使用 API 测试工具(如 Postman),访问 http://127.0.0.1:8000/,你将看到返回的 JSON 数据:{"Hello": "World"}。

五、更多实例

1. 使用 Pydantic 进行数据验证

Pydantic 是 FastAPI 的一个核心依赖,用于数据验证和设置管理。下面是一个使用 Pydantic 模型的例子:

from fastapi import FastAPI
from pydantic import BaseModel

app = FastAPI()

class Item(BaseModel):
    name: str
    price: float

@app.put("/items/{item_id}")
async def update_item(item_id: int, item: Item):
    return {"item_name": item.name, "item_id": item_id}

在这个例子中,我们定义了一个 Item 模型,包含 name 和 price 两个字段。当发送 PUT 请求到 /items/{item_id} 时,FastAPI 会自动验证请求体中的数据是否符合 Item 模型的规范。

2. 处理文件上传

FastAPI 也可以方便地处理文件上传。下面是一个文件上传的例子:

from fastapi import FastAPI, File, UploadFile
from fastapi.responses import HTMLResponse
import shutil

app = FastAPI()

UPLOAD_FOLDER = "./uploads"

@app.post("/uploadfile/")
async def create_upload_file(file: UploadFile = File(...)):
    with open(f"{UPLOAD_FOLDER}/{file.filename}", "wb") as buffer:
        shutil.copyfileobj(file.file, buffer)
    return HTMLResponse(content=f"<p>File uploaded successfully: {file.filename}</p>")

在这个例子中,我们定义了一个 POST 路由 /uploadfile/,接受一个文件作为请求体。文件会被保存到 ./uploads 文件夹中,并返回一个 HTML 响应,告知用户文件已成功上传。

3. 异步处理

FastAPI 支持异步编程,可以高效地处理大量并发请求。下面是一个异步处理的例子:

import asyncio
from fastapi import FastAPI

app = FastAPI()

@app.get("/async-test")
async def async_test():
    await asyncio.sleep(2)  # 模拟耗时操作
    return {"message": "Async operation completed"}

在这个例子中,我们定义了一个 GET 路由 /async-test,当访问该路由时,服务器会模拟一个耗时操作(等待 2 秒),然后返回一个 JSON 响应。由于使用了异步编程,这个操作不会阻塞其他请求的处理。

通过以上步骤和实例,你已经对 FastAPI 有了更深入的了解。FastAPI 还支持许多其他高级功能,如依赖注入、中间件、错误处理等,值得进一步深入学习。希望这篇文章能帮你快速上手 FastAPI,享受高效开发的乐趣!

学习交流

最后,把我的座右铭送给你:投资自己才是最大的财富。 如果你觉得本文章对你有帮助,点赞,收藏不迷路

关注公众号:我不是架构师,持续为你输出更多的硬核文章和面试经验。

相关文章

用Python进行短视频二次创作,网红必备

无论是抖音还是快手等视频平台,一旦一个视频火了后,很多 UP 主都会争先抢后去模仿拍摄或剪辑,然后上传到平台,最后都能带来不错的流量。对于一般的短视频,完全可以通过裁剪、特效转场、加入混合图层和字幕等...

告别充值,使用Python获取各大平台VIP资源

说起利用Python可以随意抓取VIP资源就很激动,今天老男孩老师就来分享给大家一个很实用的技术,只需20行代码即可爬取所有网页的VIP视频,具体是怎么实现的呢,我们快来看看吧!我们都知道有许多的视频...

老男孩教育2016年第一期免费系列课程

新的一年新的分享老男孩教育2016年首次在腾讯课程发布免费系统课程,每周三晚8点30至晚10点,不见不散!1.老师阵容:老男孩:老男孩教育的创始人,有实力不解释,你懂得~Alex:帅的不要不要的金角大...

这款自动化工具让你高效做事,优雅的摸鱼

我们经常在 PC 端使用各种 快捷键 来提高我们的办事效率;又或者 IDE 编写代码的过程中,利用 Live Templates 来快速输入常用代码。今天推荐一款工具:AutoHotkey,帮助我们在...

我有点想用JDK17了

大家下午好,JDK版本升级的非常快。JDK版本虽多,但应用最广泛的还得是JDK8,正所谓“他发任他发,我用Java8”。其实我也不太想升级JDK版本,感觉投入高,收益小,不过有一次我看到了一些使用JD...

两个日本人已经支持华语音乐20年了!原来我们从小就听日语歌长

大家伙早上好,不知道小编今天要说的这位明星大家有没有印象呢?而华语音乐的开始相对较晚,所以很多著名的国王或天后,他们的许多原创名著都是外文封面歌曲。即使到目前为止,也有很多歌曲来自外语歌曲,比如筷子哥...