Python FastAPI 快速入门

你好,我是 shengjk1,多年大厂经验,努力构建 通俗易懂的、好玩的编程语言教程。 欢迎关注!你会有如下收益:

  1. 了解大厂经验
  2. 拥有和大厂相匹配的技术等

希望看什么,评论或者私信告诉我!

一、前言

最近在做公司内部的RAG,也就是基于大模型的检索增强,专门针对公司内部的私有化数据。在这个过程中,使用了 FastAPI 来做整个 服务端 的开发。接下来我们就整体了解一下 FastAPI,争取做到基本入门

二、FastAPI

FastAPI 是一个用于构建 API 的现代、快速(高性能)的 web 框架,使用 Python 3.8+ 并基于标准的 Python 类型提示。

关键特性:

  • 快速:可与 NodeJSGo 并肩的极高性能(归功于 Starlette 和 Pydantic)。最快的 Python web 框架之一

  • 高效编码:提高功能开发速度约 200% 至 300%。*

  • 更少 bug:减少约 40% 的人为(开发者)导致错误。*

  • 智能:极佳的编辑器支持。处处皆可<abbr title="也被称为自动完成、智能感知" style="box-sizing: inherit; border-bottom: 0.05rem dotted var(--md-default-fg-color--light); cursor: help; text-decoration: none;">自动补全</abbr>,减少调试时间。

  • 简单:设计的易于使用和学习,阅读文档的时间更短。

  • 简短:使代码重复最小化。通过不同的参数声明实现丰富功能。bug 更少。

  • 健壮:生产可用级别的代码。还有自动生成的交互式文档。

  • 标准化:基于(并完全兼容)API 的相关开放标准:OpenAPI (以前被称为 Swagger) 和 JSON Schema

2.1 FastAPI安装

pip install fastapi
pip install uvicorn

Uvicorn 为 ASGI 服务器,其主要为了解决传统的同步服务器在处理大量并发请求而性能降低的问题

2.2 FastAPI基本使用

2.2.1 get方法

 from typing import Union
 from fastapi import FastAPI
 
 app = FastAPI()
 
 @app.get("/")
 def read_root():
   return {"Hello": "World"}
   
 @app.get("/items/{item_id}")
 def read_item(item_id: int, q: Union[str, None] = None):
   return {"item_id": item_id, "q": q}

使用浏览器访问 http://127.0.0.1:8000/items/5?q=somequery

你将会看到如下 JSON 响应:

{"item_id": 5, "q": "somequery"}

你已经创建了一个具有以下功能的 API:

  • 通过 路径 //items/{item_id} 接受 HTTP 请求。
  • 以上 路径 都接受 GET 操作(也被称为 HTTP 方法)。
  • /items/{item_id} 路径 有一个 路径参数 item_id 并且应该为 int 类型。
  • /items/{item_id} 路径 有一个可选的 str 类型的 查询参数 q

2.2.2 put方法

    from typing import Union
    from fastapi import FastAPI

    app = FastAPI()
    
    @app.put("/items/{item_id}")
    def read_item(item_id: int, q: Union[str, None] = None):
        return {"item_id": item_id, "q": q}

2.2.3 中间件 app.middleware

    from fastapi import FastAPI, Request

    app = FastAPI()

    @app.middleware("http")
    async def log_requests(request: Request, call_next):
        print(f"Received request: {request.method} {request.url}")
        response =await call_next(request)
        print(f"Sent response: {response.status_code}")
        return response

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

在 FastAPI 中,app.middleware 是一个装饰器,用于注册中间件函数。中间件函数可以在请求处理函数执行前或执行后对请求和响应进行处理,例如添加请求头、记录日志、验证身份等。

其中,middleware_function 是中间件函数的名称,"http" 是中间件的类型,表示它是一个 HTTP 请求中间件。request 是请求对象,call_next 是一个回调函数,用于调用下一个中间件或请求处理函数。在中间件函数中,我们可以在调用 call_next(request) 前后对请求和响应进行处理。

在这个示例中,我们定义了一个名为 log_requests 的中间件函数,它会在每个请求处理前和处理后打印请求和响应的信息。然后我们使用 app.middleware 装饰器将其注册到应用程序中。最后,我们定义了一个 GET 请求处理函数 root,它返回一个 JSON 格式的响应。

2.2.4 异常处理 app.exception_handle

from fastapi import FastAPI, HTTPException

app = FastAPI()

@app.exception_handler(ValueError)
async def value_error_handler(request, exc):
    raise HTTPException(status_code=400, detail=str(exc))

@app.get("/")
async def root():
    raise ValueError("Invalid query parameter")

@app.exception_handler 是 FastAPI 框架中的一个装饰器,用于处理应用程序中未处理的异常。当应用程序抛出未处理的异常时,FastAPI 将自动调用由 @app.exception_handler 装饰的函数,并将异常作为参数传递给该函数。这使得开发人员可以在应用程序中集中处理异常,而不必在每个路由处理程序中编写重复的异常处理代码。

在上面的代码中,当 root 路由处理程序抛出 ValueError 异常时,FastAPI 将自动调用 value_error_handler 函数,并将异常作为参数传递给该函数。value_error_handler 函数将异常转换为 HTTPException 并将其重新引发,从而返回一个带有 400 状态码和异常详细信息的 HTTP 响应。

三、总结

FastAPI 是一个现代、快速的 web 框架,使用 Python 3.8+ 并基于标准的 Python 类型提示。它具有极高的性能、高效的编码、更少的 bug、智能的编辑器支持、简单易学的设计、健壮的生产可用级别代码以及基于开放标准的标准化特性。文章详细介绍了 FastAPI 的安装、基本使用、HTTP 方法、中间件和异常处理。

四、参考

fastapi

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,258评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,335评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,225评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,126评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,140评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,098评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,018评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,857评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,298评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,518评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,400评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,993评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,638评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,661评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容