JSON 编码器
有时,我们要把 Pydantic 模型等数据类型转换为字典、列表等与 JSON 兼容的格式。
例如, 把 Pydantic 模型存入数据库时就要进行转换。
为此, FastAPI 提供了 jsonable_encoder()
函数。
使用 jsonable_encoder
假设数据库 fake_db
只接收与 JSON 兼容的数据。
该数据库不能接收与 JSON 不兼容的 datetime
对象。
因此必须把 datetime
对象转换为包含 ISO 格式数据的字符串。
同理,该数据库也不能接收 Pydantic 模型(带属性的对象),只能接收字典。
接收 Pydantic 模型要使用 jsonable_encoder
。
jsonable_encoder
函数接收 Pydantic 模型等对象,然后返回兼容 JSON 的数据:
from datetime import datetime
from fastapi import FastAPI
from fastapi.encoders import jsonable_encoder
from pydantic import BaseModel
import pymongo
client = pymongo.MongoClient("mongodb://192.168.10.230:27017/")
myset = client['test']['demo']
class Item(BaseModel):
title: str
timestamp: datetime
description: str | None = None
app = FastAPI()
@app.put("/items/{id}")
def update_item(id: str, item: Item):
json_compatible_item_data = jsonable_encoder(item)
print(type(json_compatible_item_data))
print("===================================>开始插入数据")
myset.insert_one(json_compatible_item_data)
print("===================================>插入数据完成")
return json_compatible_item_data["title"]
以上代码 把Pydantic 模型转换为字典,并把 datetime
转换为字符串。jsonable_encoder
函数返回的不是包含 JSON 数据的长字符串,而是返回值与子值都兼容 JSON 的 Python 标准数据结构,比如字典。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)