pydantic学习与使用-8.required-fields必填字段省略号( ...)

2022-03-03 15:35:02 浏览数 (1)

前言

必填字段可以仅用注释来声明,也可以使用省略号 ( …) 作为值:

必填字段

必填字段,可以仅用注释来声明,以下name和age2个字段是必填字段

代码语言:javascript复制
from pydantic import BaseModel

class User(BaseModel):
    name: str
    age: int
    city: str = '上海市'

必填字段也可以使用省略号 ( …) 作为值

代码语言:javascript复制
from pydantic import BaseModel

class User(BaseModel):
    name: str = ...
    age: int = ...
    city: str = '上海市'

也可以用 Field 类,这里 Field 类指的是 field function.

代码语言:javascript复制
from pydantic import BaseModel, Field

class User(BaseModel):
    name: str = ...
    age: int = Field(...)
    city: str = '上海市'

这里 name 和 age 都是必填字段,但是str = ...这种语法在 mypy 里并不会工作,所以在v1.0版本后,就尽量不用省略号了

必填可选字段(Required Optional fields)

由于v1.2 版本注释仅适用于可空字段(Optional[…], Union[None, …] and Any)和带省略号(…)的可空字段作为默认值,不再表示相同的内容。

代码语言:javascript复制
from typing import Optional
from pydantic import BaseModel, Field, ValidationError

class Model(BaseModel):
    a: Optional[int]
    b: Optional[int] = ...
    c: Optional[int] = Field(...)

print(Model(b=1, c=2))
#> a=None b=1 c=2
try:
    Model(a=1, b=2)
except ValidationError as e:
    print(e)
    """
    1 validation error for Model
    c
      field required (type=value_error.missing)
    """

在上面示例中,a,b,c都可以传None值,但是 a是可选的,可以不用传值。b和c是必填项,可以传None值。

0 人点赞