RootModel
RootModel class and type definitions.
RootModel ¶
RootModel(
root: RootModelRootType = PydanticUndefined, **data
)
Bases: BaseModel
, Generic[RootModelRootType]
Usage Documentation
A Pydantic BaseModel
for the root object of the model.
Attributes:
Name | Type | Description |
---|---|---|
root |
RootModelRootType
|
The root object of the model. |
__pydantic_root_model__ |
Whether the model is a RootModel. |
|
__pydantic_private__ |
Private fields in the model. |
|
__pydantic_extra__ |
Extra fields in the model. |
Source code in pydantic/root_model.py
63 64 65 66 67 68 69 70 71 |
|
model_construct
classmethod
¶
Create a new model using the provided root object and update fields set.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
root |
RootModelRootType
|
The root object of the model. |
required |
_fields_set |
set[str] | None
|
The set of fields to be updated. |
None
|
Returns:
Type | Description |
---|---|
Model
|
The new model. |
Raises:
Type | Description |
---|---|
NotImplemented
|
If the model is not a subclass of |
Source code in pydantic/root_model.py
75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 |
|
model_dump ¶
model_dump(
*,
mode: Literal["json", "python"] | str = "python",
include: Any = None,
exclude: Any = None,
context: dict[str, Any] | None = None,
by_alias: bool = False,
exclude_unset: bool = False,
exclude_defaults: bool = False,
exclude_none: bool = False,
round_trip: bool = False,
warnings: bool
| Literal["none", "warn", "error"] = True,
serialize_as_any: bool = False
) -> Any
This method is included just to get a more accurate return type for type checkers.
It is included in this if TYPE_CHECKING:
block since no override is actually necessary.
See the documentation of BaseModel.model_dump
for more details about the arguments.
Generally, this method will have a return type of RootModelRootType
, assuming that RootModelRootType
is
not a BaseModel
subclass. If RootModelRootType
is a BaseModel
subclass, then the return
type will likely be dict[str, Any]
, as model_dump
calls are recursive. The return type could
even be something different, in the case of a custom serializer.
Thus, Any
is used here to catch all of these cases.
Source code in pydantic/root_model.py
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 |
|