繁体   English   中英

从 Python 数据类动态创建 Pydantic model

[英]Creating a Pydantic model dynamically from a Python dataclass

我想从一个数据类动态创建一个 Pydantic model,类似于如何从一个数据类动态创建棉花糖模式,如棉花糖数据类或https://stevenloria.com/dynamic-schemas-in-marshmallow/ 是否已经有一个图书馆或简单的方法来做到这一点?

一些背景知识——我更喜欢在我的业务逻辑中使用数据类,而不是直接使用 Pydantic model。 我仅在我的 FastAPI 应用程序中使用 Pydantic model 对带有驼峰式字段的数据进行序列化/反序列化。 但是,我发现自己基本上复制了效率不高的数据类定义。

样本输入:

from typing import List

from dataclasses import dataclass


@dataclass
class Item:
    id: int = None
    stuff: str = None
    height: float = None


@dataclass
class Bag:
    id: int = None
    name: str = None
    things: List[Item] = None


@dataclass
class Basket:
    id: int = None
    recipient: str = None
    bags: List[Bag] = None
    best_item: Item = None

所需的 output:

from typing import List

from pydantic.main import BaseModel


def camel_case_converter(value: str):
    parts = value.lower().split('_')
    return parts[0] + ''.join(i.title() for i in parts[1:])


class CamelBaseModel(BaseModel):
    class Config:
        alias_generator = camel_case_converter


class Item(CamelBaseModel):
    id: int = None
    stuff: str = None
    height: float = None


class Bag(CamelBaseModel):
    id: int = None
    name: str = None
    things: List[Item] = None


class Basket(CamelBaseModel):
    id: int = None
    recipient: str = None
    bags: List[Bag] = None
    best_item: Item = None

也许是这样的? (来自https://github.com/samuelcolvin/pydantic/issues/1967#issuecomment-742698281

from typing import Type

from pydantic import BaseModel
from pydantic.dataclasses import dataclass as pydantic_dataclass
from typing import List

from dataclasses import dataclass


def model_from_dataclass(kls: 'StdlibDataclass') -> Type[BaseModel]:
    """Converts a stdlib dataclass to a pydantic BaseModel"""
    return pydantic_dataclass(kls).__pydantic_model__

@dataclass
class Item:
    id: int = None
    stuff: str = None
    height: float = None

ItemBaseModel = model_from_dataclass(Item)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM