Python零基础从小白打怪升级中~~~~~~~FaskAPI中的请求和响应

2024-04-12 07:12

本文主要是介绍Python零基础从小白打怪升级中~~~~~~~FaskAPI中的请求和响应,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第二节:FastAPI中请求数据

一、URL请求参数

url请求参数是通过url请求地址携带的,例如,在以下 url 中:

http://127.0.0.1:8000/items/?skip=0&limit=10

这些请求参数是键值对的集合,这些键值对位于 URL 的 之后,并以 & 符号分隔。

请求参数为:

  • skip:对应的值为 0
  • limit:对应的值为 10

当你为它们声明了 Python 类型(在上面的示例中为 int)时,它们将转换为该类型并针对该类型进行校验。

from fastapi import FastAPIapp = FastAPI()fake_items_db = [{"item_name": "Foo"}, {"item_name": "Bar"}, {"item_name": "Baz"}]@app.get("/items/")
def read_item(skip: int = 0, limit: int = 10):return fake_items_db[skip : skip + limit]

URL请求参数不是路径的固定部分,因此它们可以是可选的,并且可以有默认值。

在上面的示例中,它们具有 skip=0limit=10 的默认值。你可以将它们的默认值设置为 None

from typing import Unionfrom fastapi import FastAPIapp = FastAPI()@app.get("/items/{item_id}")
async def read_item(item_id: str, q: Union[str, None] = None, short: bool = False):item = {"item_id": item_id}if q:item.update({"q": q})if not short:item.update({"description": "This is an amazing item that has a long description"})return item

Union是Python 3.10版本引入的新类型,它允许创建多种类型的联合(union)。,Union类型是一种用于表示一个变量可以是多个不同类型之一的类型注解。它是typing模块中的一个类,可以与其他类型一起使用,以指定一个变量可以接受的多个类型。

Union类型的语法为:Union[type1, type2, …]
这里的type1、type2等代表要包含在Union类型中的类型。

注意:当你想让一个查询参数成为必需的,不声明任何默认值就可以:

@app.get("/items/{item_id}")
def read_user_item(item_id: str, needy: str, skip: int = 0, limit: Union[int, None] = None
):item = {"item_id": item_id, "needy": needy, "skip": skip, "limit": limit}return item

在这个例子中,有3个查询参数:

  • needy,一个必需的 str 类型参数。
  • skip,一个默认值为 0int 类型参数,也是可选的。
  • limit,一个可选的 int 类型参数。

二、请求数据校验

1、Query校验数据

QueryFastAPI专门用来装饰请求参数的类,也可以提供校验。

1)默认值设置,和参数接口描述

@app.get("/items/")
async def read_items(q: Union[str, None] = Query(default=None, description="参数q可以传入字符串或者不传")):query_items = {"q": q}return query_items

descriptionQuery中的一个字段,用来描述该参数;

2)字符串长度校验

@app.get("/items2/")
async def read_items(q: Union[str, None] = Query(default=None, max_length=50, min_length=3)):query_items = {"q": q}return query_items

注意:max_lengthmin_length仅可用于 str 类型的查询参数。

3)正则表达式校验

@app.get("/items3/")
async def read_items(q: Union[str, None] = Query(default=None, regex="^laoxiao$")
):query_items = {"q": q}return query_items

也就是说该接口的查询参数只能是" laoxiao",不然就会报错,当然其他的正则表达式都是可以拿来用的!

4)数值大小校验

如果参数的类型是int,float就可以采用Query进行大小校验,或者范围校验。

@app.get("/test4/")
async def read_items4(id: int = Query(description="id参数必须是0到1000之间", gt=0, le=1000), q: str = Query(default=None)):results = {"item_id": id}if q:results.update({"q": q})return results
  • gt:大于(greater than)
  • ge:大于等于(greater than or equal)
  • lt:小于(less than)
  • le:小于等于(less than or equal)

三、url请求参数中传入一组值

我们还可以使用 Query 去接收一组值。使用 List[str] 来接收一组值,里面的str可以根据需求随意调换。

@app.get("/test5/")
async def read_items(q: Union[List[str], None] = Query(default=None, description='q可以传入多个值')):query_items = {"q": q}return query_items

image.png

这是因为参数 q中以一个 Python list 的形式接收到查询参数 q 的多个值。

这篇关于Python零基础从小白打怪升级中~~~~~~~FaskAPI中的请求和响应的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/896449

相关文章

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re