如何从 pydantic 模型解析和读取“_id”字段?

ros*_*hii 19 python mongodb pydantic

我正在尝试将 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())
Run Code Online (Sandbox Code Playgroud)

User_1解析成功,因为它的_id字段是必需的,但之后无法读取。 User_2在上面的示例中,如果附加到 Mongo 则失败,但 Mongo 不提供任何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']}
Run Code Online (Sandbox Code Playgroud)

SCo*_*vin 31

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

from pydantic import BaseModel, Field

class User_1(BaseModel):
    id: int = Field(..., alias='_id')
Run Code Online (Sandbox Code Playgroud)

请参阅此处的文档。

  • 谢谢!对于那些希望将对象转换回包含“_id”的字典的人,只需使用“User_1(_id=1234).dict(by_alias=True)”,这样你最终会得到一个具有“_id”键的字典。 (8认同)