FastAPI:Python打造高效API的终极武器

news2025/4/9 0:42:44

在Python的世界里,如果你想要一个既快速又现代的方式来构建API,那么FastAPI可能是你的首选。这个库基于Starlette(用于Web编程)和Pydantic(用于数据验证),专门为速度和易用性设计。

image-20240429143040552

什么是FastAPI?

FastAPI 是一个用于构建API的现代、快速(高性能)框架,使用Python 3.6及以上版本,基于标准Python类型提示。它允许开发者使用Python的类型提示来声明请求和响应的数据模型,从而使得API具有自动生成的文档(Swagger UI),并支持数据验证和序列化。

核心特性:
  1. 快速:FastAPI框架非常快。其性能可与NodeJS和Go相媲美,主要得益于Starlette(用于Web微服务的工具集)和Pydantic(数据验证库)。
  2. 简单易用:设计目的是易于使用和学习,减少可能的错误。
  3. 自动生成文档:使用Swagger和ReDoc,FastAPI会自动为你生成交互式API文档。

FastAPI 的原理

FastAPI 使用 Python 的类型提示增强其性能和错误处理能力。当你创建一个API函数时,你可以给每个函数参数添加类型提示,FastAPI 会使用这些信息来执行请求参数的验证和序列化。

快速入门示例

步骤 1:安装FastAPI和Uvicorn

首先,我们需要安装FastAPI框架和Uvicorn,一个光速ASGI服务器,用于运行我们的应用。

pip install fastapi uvicorn
步骤 2:创建一个基本的API

接下来,我们写一个简单的应用来展示FastAPI的基础功能,将代码保存为example.py。

from fastapi import FastAPI

app = FastAPI()

@app.get("/")
async def read_root():
    return {"Hello": "World"}
步骤 3:运行服务器

运行上面的应用非常简单,只需要在命令行中执行以下命令:

uvicorn example:app --reload

这条命令会启动服务器,并且每当你修改代码后,服务器会自动重新加载。

步骤 4:测试API

打开你的浏览器或者使用工具如Postman,访问 http://127.0.0.1:8000/,你将看到像这样的响应:

image-20240429115243099

进阶示例

from fastapi import FastAPI
from pydantic import BaseModel
from typing import List

app = FastAPI()

class Book(BaseModel):
    title: str
    author: str
    price: float
    in_stock: int

# 初始化books_db,确保每个条目都是Book对象
books_db: List[Book] = [
    Book(title="西游记", author="吴承恩", price=100.0, in_stock=10),
    Book(title="三国演义", author="罗贯中", price=120.0, in_stock=15),
    Book(title="水浒传", author="施耐庵", price=110.0, in_stock=5),
    Book(title="红楼梦", author="曹雪芹", price=130.0, in_stock=8)
]

@app.post("/books/")
async def add_book(book: Book):
    books_db.append(book)
    return {"msg": "Book added successfully", "book": book}

@app.get("/books/", response_model=List[Book])
async def get_books():
    return books_db

执行步骤

  1. 保存上述代码到一个名为example.py的文件中。

  2. 在你的开发环境中安装FastAPI和uvicorn:

    pip install fastapi uvicorn
    
  3. 在命令行中运行下面的命令来启动服务器:

    uvicorn example:app --reload
    
  4. 使用浏览器或API测试工具(如Postman)来发送请求:

    • 发送POST请求到http://127.0.0.1:8000/books/以添加新书。
    • 发送GET请求到http://127.0.0.1:8000/books/以查看所有书籍。

执行效果

image-20240429142128405

FastAPI 的官方文档是学习资源的宝库,提供了详尽的指南和API参考。

FastAPI 官方文档:https://fastapi.tiangolo.com/

FastAPI GitHub:https://github.com/tiangolo/fastapi

FastAPI提供了一个强大而灵活的方式来构建API,其性能优异,自动化文档和数据验证功能可以大大加快开发速度。适合需要快速迭代和部署的现代Web应用。

希望这篇文章能帮助你了解FastAPI的基本用法和构建高效API的能力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1673663.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

搞懂Docker(九)- 使用Docker Compose

获取示例程序 示例程序 或者 示例程序 获取示例程序程序结构如下├── getting-started-app/ │ ├── package.json │ ├── README.md │ ├── spec/ │ ├── src/ │ └── yarn.lock使用Docker Compose Docker Compose是一个帮助你定义和共享多容器应用程序的工具…

Linux系统编程:进程控制

1.进程创建 1.1 fork函数 fork()通过复制调用进程来创建一个新进程。新进程称为子进程,是调用进程的精确副本 进程,但以下几点除外: 子进程有自己的PID,此PID与任何现有进程组的ID不匹配子进程的父进程ID…

qt: undefined reference to `vtable for aaa‘

版本qt4.8.6&#xff0c;编译报错“main.cpp:(.text0x3b): undefined reference to vtable for aaa” 就一个main.cpp #include <QApplication> #include <QTimer> #include <QCursor> #include <QMouseEvent> #include <QDesktopWidget> #inc…

代驾+顺风车+货运app功能介绍

代驾货运顺风车同城拼车打车网约车系统源码app小程序是一个功能丰富的平台&#xff0c;支持二次开发和定制&#xff0c;以满足不同运营商的需求。以下是关于该系统的功能详情介绍&#xff1a; 一、核心功能 会员管理&#xff1a;包括用户注册、登录、个人信息管理等功能&…

yarn 安装以及报错处理

前一种报错是由于没有安装yarn导致的&#xff0c;使用以下命令即可安装&#xff1a; npm install -g yarn 如果成功安装&#xff0c;将显示Yarn的版本号。 yarn --version 第二种报错是因为系统上的执行策略限制导致的。执行策略是一种安全功能&#xff0c;用于控制在计算机…

第15节 编写shellcode加载器

我最近在做一个关于shellcode入门和开发的专题课&#x1f469;&#x1f3fb;‍&#x1f4bb;&#xff0c;主要面向对网络安全技术感兴趣的小伙伴。这是视频版内容对应的文字版材料&#xff0c;内容里面的每一个环境我都亲自测试实操过的记录&#xff0c;有需要的小伙伴可以参考…

HCIP的学习(17)

BGP基础配置 使用直连接口IP地址来建立EBGP对等体关系 1、启动BGP协议 [r1]bgp 100 ----启动BGP协议&#xff0c;并且规定其AS号2、配置设备的RID数值&#xff0c;一般选择设备的loopback接口的IP地址 [r1-bgp]router-id 1.1.1.13、配置BGP对等体信息&#xff0c;包含了对等体…

【声呐仿真】学习记录3-待续

【声呐仿真】学习记录3-后续 第五阶段-获取数据1.运行赫尔库勒斯沉船的世界&#xff1a;2.键盘操纵rov至合适的位置&#xff0c;调整Image topic&#xff0c;查看输出图像3.RVIZ SONAR 图像查看器插件&#xff08;没有对应的topic&#xff09;4.点云5.录制rosbag 第六阶段-查看…

问题—前端调用接口url多加一个/,本地可以调通,测试环境报错302,分开调两个接口

问题背景 接口url前面多加一个/ &#xff0c;npm run serve 起项目&#xff0c;本地调用正常 npm run build 打包到测试环境&#xff0c;接口出现问题&#xff0c;分开调用接口&#xff0c;且报302错误 问题原因&#xff1a; 本地开发环境和测试环境的URL处理方式不同 本地使…

专业的服贸会服务团队-媒体邀约宣传

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 2024服贸会开展在即&#xff0c;许多企业都做好了的参展的准备&#xff0c;北京麦塔文化提供专业的展览展会服务&#xff0c;下面做个简单介绍。 、会场搭建团队&#xff1a; 负责整个活…

Ansys Zemax|HUD 设计实例

说明 本文介绍了HUD设计实例。 实例说明 规格如下&#xff1a; 显示器尺寸&#xff1a;24*8mm 眼盒尺寸&#xff1a;100*40mm 放大倍率&#xff1a;5 &#xff08;虚像尺寸 120*40mm&#xff09; 虚像距离&#xff1a;1.8m 最终光学系统的整体布局如下图所示。 从HUD发出的…

478.8-480W 宽电压输入 AC/DC 导轨式开关电源——TPR/SDR-480-XS 系列

TPR/SDR-480-XS 系列导轨式开关电源&#xff0c;额定输出功率为478.8-480W&#xff0c;产品输入范围&#xff1a;85-264VAC。提供24V、36V、48V输出&#xff0c;具有短路保护&#xff0c;过载保护等功能&#xff0c;并具备高效率&#xff0c;高可靠性、高寿命、更安全、更稳定等…

GRFB-UNet:一种新的多尺度注意力网络,用于铺路分割

不同场景下的带注释的触觉铺装示例: GRFB-UNet网络结构: GRFB模块的结构: 铺路在视障人士的旅行中起着至关重要的作用。因此,识别铺装的形状和位置以支持视障人士的移动性是相当有意义的,而视觉分割技术就适合这项任务。为了有效提高触觉铺装分割的精度和鲁棒性,…

RS485和RS232区别

RS485和RS232接口在物理外观上的区别主要在于连接器的类型和接线方式上。这两种串行通讯接口虽然在功能上有所不同&#xff0c;但外观上也有一些显著的特点。 连接器类型&#xff1a; RS232 接口通常使用DB9或DB25类型的连接器。DB9是较为常见的&#xff0c;拥有9个针脚&#x…

小程序的小组件

进度的组件 文字换行过滤 以及 排序 简单易懂 只为了记录工作 <template><div><ProgressBar :progress"progress" /><button click"increaseProgress">增加进度</button><view class"goods-name">12…

Ubuntu18.04安装OpenCV和OpenCV_Contrib

1. &#xff08;如果需要&#xff09;卸载已安装的OpenCV库 删除opencv其他的相关文件 sudo rm -r /usr/local/include/opencv2 sudo rm -r /usr/local/include/opencv sudo rm -r /usr/include/opencv sudo rm -r /usr/include/opencv2 sudo rm -r /usr/local/share/opencv…

C语言 文件操作

目录 1. 什么是文件&#xff1f;2. 二进制文件和文本文件3. 文件的打开和关闭3.1 流和标准流3.1.1 流3.1.2 标准流 3.2 文件指针3.3 打开、关闭文件3.3.1 fopen - 打开文件3.3.2 fclose - 关闭文件 4. 文件的顺序读写4.1 fgetc - 从文件流获取一个字符4.2 fputc - 将一个字符写…

Unreal自定义字体中,缺少字怎么办,有没有字表?

关键词&#xff1a;自定义字体&#xff0c;字表&#xff0c;编码&#xff0c;UTF-8,4E00-9FFF,4E00-9FA5,字符查重&#xff0c;字符唯一&#xff0c; 问题&#xff1a; 游戏中经常要自定义字体&#xff0c; 自定义字体往往要做离线字库 offline fonts 离线字库 离不开字符表。…

Qt实现水平方向流式布局FlowLayout简单又实用!

Qt中常见的布局管理器有&#xff1a; QHBoxLayout&#xff1a;水平布局&#xff08;常用&#xff09; QVBoxLayout&#xff1a;垂直布局&#xff08;常用&#xff09; QGridLayout&#xff1a;表格布局&#xff08;常用&#xff09; QFormLayout&#xff1a;表单布局&#…

009.Rx(Reactive Extenstions)的关系

响应式扩展库在组成响应式系统的应用程序中发挥作用&#xff0c;它与消息驱动的概念相关。Rx不是在应用程序或服务器之间移动消息的机制&#xff0c;而是在消息到达时负责处理消息并将其沿着应用程序内部的执行链传递的机制。需要说明的是&#xff0c;即使您没有开发包含许多组…