系列文章:

  FastAPI 学习之路(一)fastapi--高性能web开发框架

  FastAPI 学习之路(二)

  FastAPI 学习之路(三)

  FastAPI 学习之路(四)

  FastAPI 学习之路(五)

FastAPI 学习之路(六)查询参数,字符串的校验

  FastAPI 学习之路(七)字符串的校验

   FastAPI 学习之路(八)路径参数和数值的校验

  FastAPI 学习之路(九)请求体有多个参数如何处理?

  FastAPI 学习之路(十)请求体的字段

FastAPI 学习之路(十一)请求体 - 嵌套模型

一、额外信息

我们有这样的一个需求,我们希望可以看到接口的一个简单的请求示例展示在我们的接口文档中,应该如何实现呢。我们看下如何实现的:
from typing import Optional

from fastapi import FastAPI
from pydantic import BaseModel
app = FastAPI()
class Item(BaseModel):
name: str
description: Optional[str] = None
price: float
tax: Optional[float] = None
class Config:
schema_extra = {
"example": {
"name": "DEMO",
"description": "DEMO",
"price": 20,
"tax": 0.5,
}
}
@app.post("/items/")
def return_item( item: Item):
results = { "item": item}
return results

那么我们请求下试试。

接口满足我们的请求,我们看下接口文档是否有请求的示例。

接口文档是正常有这个的示例。代码中使用Config 和 schema_extra 为Pydantic模型声明一个简单的示例。

其实我们在Field也会可以实现一个额外的信息,比如我们增加一个example字段,我们看下如何实现的,带来什么样的效果

from typing import Optional
from fastapi import FastAPI
from pydantic import BaseModel,Field
app = FastAPI()
class Item(BaseModel):
name: str
description: Optional[str] = None
price:float = Field(..., example=600)
tax: Optional[float] = Field(None, example=0.5) @app.post("/items/")
def return_item( item: Item):
results = { "item": item}
return results

我们看下效果,正常的接口请求没有变动。

我们看下接口的文档。文档在解析的时候,会解析出来这个额外的信息。

当然像Body,Path等也都可以增加这些参数。

二、 额外数据类型

到目前为止,您一直在使用常见的数据类型,如:

  • int

  • float

  • str

  • bool

但是您也可以使用更复杂的数据类型。

您仍然会拥有现在已经看到的相同的特性:

  • 很棒的编辑器支持。

  • 传入请求的数据转换。

  • 响应数据转换。

  • 数据验证。

  • 自动补全和文档。

其他数据类型

下面是一些你可以使用的其他数据类型:

  • UUID:

    • 一种标准的 "通用唯一标识符" ,在许多数据库和系统中用作ID。

    • 在请求和响应中将以 str 表示。

  • datetime.datetime:

    • 一个 Python datetime.datetime.

    • 在请求和响应中将表示为 ISO 8601 格式的 str ,比如: 2008-09-15T15:53:00+05:00.

  • datetime.date:

    • Python datetime.date.

    • 在请求和响应中将表示为 ISO 8601 格式的 str ,比如: 2008-09-15.

  • datetime.time:

    • 一个 Python datetime.time.

    • 在请求和响应中将表示为 ISO 8601 格式的 str ,比如: 14:23:55.003.

  • datetime.timedelta:

    • 一个 Python datetime.timedelta.

    • 在请求和响应中将表示为 float 代表总秒数。

    • Pydantic 也允许将其表示为 "ISO 8601 时间差异编码", 查看文档了解更多信息。

  • frozenset:

    • 在请求中,列表将被读取,消除重复,并将其转换为一个 set

    • 在响应中 set 将被转换为 list 。

    • 产生的模式将指定那些 set 的值是唯一的 (使用 JSON 模式的 uniqueItems)。

    • 在请求和响应中,作为 set 对待:

  • bytes:

    • 标准的 Python bytes

    • 在请求和相应中被当作 str 处理。

    • 生成的模式将指定这个 str 是 binary "格式"。

  • Decimal:

    • 标准的 Python Decimal

    • 在请求和相应中被当做 float 一样处理。

下面是一个接口操作的示例,其中的参数使用了上面的一些类型。

from typing import Optional
from uuid import UUID
from fastapi import Body, FastAPI
from datetime import datetime, time, timedelta
app = FastAPI()
@app.put("/items/{id}")
async def read_items(
item_id: UUID,
start_time: Optional[datetime] = Body(None), end_time: Optional[datetime] = Body(None), after: Optional[timedelta] = Body(None), ):
start_process = start_time
duration = end_time - start_process
return {
"id": item_id,
"start_datetime": start_time,
"end_datetime": end_time,
"after": after,
"start_process": start_process,
"duration": duration,
}

那么我们看下接口文档的请求。

UUId来源        http://www.uuid.online/可以生成。

这样就是我们利用了这些参数的一个请求。

文章首发在公众号,欢迎关注。

最新文章

  1. 关于jni编译32位、64位动态库(Android.mk和Application.mk文件)
  2. XMLHttpRequest对象用法
  3. java提高篇(十一)-----强制类型转换
  4. Java横向、纵向合并图片
  5. dictionary 添加数据
  6. 各大Oj平台介绍
  7. thinkphp 防止sql注入
  8. iOS平常注意1
  9. Java 并发——多线程基础
  10. HDU 2653 - Waiting ten thousand years for Love
  11. 2016 UESTC Training for Dynamic Programming
  12. ORA-00245问题总结
  13. Dynamics CRM 安装Microsoft Dynamics CRM Reporting Extensions
  14. EasyUI的datagrid加载数据去掉遮罩
  15. iOS开发简记(4):录音AVAudioRecorder
  16. hybrid programming based on python and C/C++
  17. angular 2 - 003 typescript
  18. java中的内部类详解
  19. shell中>/dev/null 2>&1
  20. Python之Requests的高级用法

热门文章

  1. Java反射的浅显理解
  2. kubernetes 使用 PV 和 PVC 管理数据存储
  3. Git 系列教程(1)- Git 简介
  4. linux网络编程(一)
  5. 快速模式第一包: quick_outI1()
  6. IPsec 9个包分析(主模式+快速模式)
  7. L2TP协议简介
  8. git各种操作:基本操作 and 多人协作 and 冲突解决
  9. AS插件快速生成javabean
  10. Matlab使用随记