3

我正在尝试将 MongoDB 数据解析为一个 pydantic 模式,但未能读取其_id似乎刚刚从模式中消失的字段。
这个问题肯定与对象属性前面的下划线有关。我无法更改_id字段名称,因为这意味着根本不解析该字段。
请在下面找到我使用的代码(为了简化而使用int而不是)ObjectId

from pydantic import BaseModel

class User_1(BaseModel):
    _id: int

data_1 = {"_id": 1}

parsed_1 = User_1(**data_1)
print(parsed_1.schema())

class User_2(BaseModel):
    id: int

data_2 = {"id": 1}

parsed_2 = User_2(**data_2)
print(parsed_2.schema())

User_1解析成功,因为它的_id字段是必需的,但之后无法读取。 User_2如果附加到不提供任何id字段但_id.

上面代码的输出如下:

User_1  {'title': 'User_1', 'type': 'object', 'properties': {}}
User_2  {'title': 'User_2', 'type': 'object', 'properties': {'id': {'title': 'Id', 'type': 'integer'}}, 'required': ['id']}
4

1 回答 1

11

您需要为该字段名称使用别名

from pydantic import BaseModel, Field

class User_1(BaseModel):
    id: int = Field(..., alias='_id')

请参阅此处的文档。

于 2020-01-02T12:11:17.787 回答