Para problemas de formato y tipo de datos, fastapi tiene un buen convertidor incorporado.Este artículo registra principalmente el contenido relevante de codificación y solicita contenido relacionado con la actualización;
codificador compatible con json
class Animal(BaseModel):
name: str = "JACK"
age: int = 21
birthday: datetime = datetime.now()
@app08.put("/stu08/json_update/")
def stu07_update(animal: Animal):
print("animal__type:", type(animal), "animal:", animal)
json_data = jsonable_encoder(animal)
print("animal__type:", type(json_data), "animal:", json_data)
return animal
# 输出结果
# animal__type: <class 'stu.stu07.Animal'> animal: name='JACK' age=21 birthday=datetime.datetime(2022, 12, 2, 18, 31, 38, 373484)
# animal__type: <class 'dict'> animal: {'name': 'JACK', 'age': 21, 'birthday': '2022-12-02T18:31:38.373484'}
Ahora, la mayoría de nuestras solicitudes son
Pydantic
tipos de modelos, que no son compatibles con las aplicaciones reales, como almacenarlos en la base de datos, y el uso de las funciones integradasjsonable_encoder()
de fastapi puede resolver bien los problemas relacionados; realizarán la conversión de tipos, por ejemplopydantic转dict
,datetime转str
...
Solicitud PUT para actualizar datos
class City(BaseModel):
province: Optional[str] = Field("重庆")
cityname: Optional[str] = Field("重庆")
gdp: Optional[float] = Field(236542.25)
towns: Optional[List[str]] = Field(["奉节","云阳","万州"])
population: Optional[int] = Field(562312)
cityitem = {
1: {
"province": "四川",
"cityname": "成都",
"gdp": 12653.56,
},
2: {
"province": "山西",
"cityname": "太原",
"gdp": 10003.56,
"towns": ["清徐", "小店", "迎泽"],
"population": 556565
},
3: {
"province": "吉林",
"cityname": "长春",
"gdp": 10253.85,
"towns": [],
"population": 54160
}
}
@app08.put("/stu08/cityput/{cityid}")
async def stu08_city_put(
city: City = Body(default={
"province": "湖南",
"cityname": "长沙",
"gdp": 15553.85,
"towns": ["安化"],
"population": 236160
}),
cityid: int = Path(ge=1, le=3),
):
update_city = jsonable_encoder(city)
cityitem[cityid] = update_city
print(cityitem)
return update_city
PUT
Actualizar datos es muy simple. Acepte un cuerpo de solicitud del mismo tipo, decodifique el cuerpo de solicitud recibido y realice la conversión de tipo correspondiente (basada en el codificador JSON anterior) y luego almacene los datos:
Solicitud PATCH para actualizar datos
@app08.patch("/stu08/citypatch/{cityid}")
async def stu08_city_patch(
city: City,
cityid: int = Path(ge=1, le=3),
):
city_item_data = cityitem[cityid] # 获取cityitem内对应id的数据
city_item_model = City(**city_item_data) # 将获取到的数据转为City类型
city_item_update = city.dict(exclude_unset=True) # 将获取的数据设置为不包含默认值的字典
city_item_update_result = city_item_model.copy(update=city_item_update) # 使用pydantic方法进行数据更新
cityitem[cityid] = jsonable_encoder(city_item_update_result) # 将更新后的数据进行编码并放回cityitem
print(cityitem)
return city_item_update_result
Esta es una actualización parcial, solo entienda el método. En aplicaciones prácticas, el método PUT se usa a menudo. Para el proceso específico, consulte los comentarios del código anterior;
¡Gracias por leer!
Dirección de Jiumozhai: https://blog.jiumoz.com/archives/fastapi-cong-ru-men-dao-shi-zhan-14json-bian-ma-jian-rong-yu-geng-xin-qing-qiu