前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >FastAPI从入门到实战(14)——JSON编码兼容与更新请求

FastAPI从入门到实战(14)——JSON编码兼容与更新请求

作者头像
MinChess
发布2022-12-27 20:00:35
5960
发布2022-12-27 20:00:35
举报
文章被收录于专栏:九陌斋九陌斋

针对数据格式和类型问题,fastapi内置了一个很好的转换器,本文就相关内容主要记录编码和请求更新相关内容;

json兼容编码器

代码语言:javascript
复制
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'}

现在我们的请求大多都是Pydantic模型类的,在实际的应用中并不会兼容,例如存储到数据库中,利用fastapi内置的jsonable_encoder()函数就能很好的解决相关的问题;会进行类型的转换,例如pydantic转dictdatetime转str

PUT请求更新数据

代码语言:javascript
复制
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更新数据很简单,接受一个同类型的请求体,将接收的请求体进行解码,就是进行对应的类型转换(基于上面的JSON编码器),然后进行数据存储:

PATCH请求更新数据

代码语言:javascript
复制
@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

这个就是部分更新,了解方法即可,实际应用中,还是PUT方法用的多,具体过程参看上面代码的注释;


感谢阅读!

九陌斋地址:https://cloud.tencent.com/developer/article/2200724

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-12-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • json兼容编码器
  • PUT请求更新数据
  • PATCH请求更新数据
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档