作者:麦克煎蛋 出处:https://www.cnblogs.com/mazhiyong/ 转载请保留这段声明,谢谢!
FastAPI 基于 Pydantic
,Pydantic
主要用来做类型强制检查。参数赋值,不符合类型要求就会抛出异常。
对于 API 服务,支持类型检查非常有用,会让服务更加健壮,也会加快开发速度,因为开发者再也不用自己写一行一行的做类型检查。
我们用纯粹的,经典的Python来定义数据,用Pydantic来校验数据。
官方文档地址:https://pydantic-docs.helpmanual.io/
一、安装
pip install pydantic
二、使用
from pydantic import ValidationError from datetime import datetime from typing import List from pydantic import BaseModel class User(BaseModel): id: int name = 'jack guo' signup_timestamp: datetime = None friends: List[int] = []
观察到:
- id 要求必须为 int
- name 要求必须为 str, 且有默认值
- signup_timestamp 要求为 datetime, 默认值为 None
- friends 要求为 List,元素类型要求 int, 默认值为 []
使用 User 类:
try: User(signup_timestamp='not datetime', friends=[1, 2, 3, 'not number']) except ValidationError as e: print(e.json())
id
没有默认值,按照预期会报缺失的异常
signup_timestamp
被赋为非 datetime 类型值,按照预期会报异常
friends
索引为 3 的元素被赋值为 str,按照预期也会报异常
执行代码,验证是否符合预期。
[ { "loc": [ "id" ], "msg": "field required", "type": "value_error.missing" }, { "loc": [ "signup_timestamp" ], "msg": "invalid datetime format", "type": "value_error.datetime" }, { "loc": [ "friends", 3 ], "msg": "value is not a valid integer", "type": "type_error.integer" } ]
参考文章:https://cloud.tencent.com/developer/article/1593589
更复杂的使用和例子可以参考官方文档。