Source code for pydelfini.delfini_core.models.table
from typing import Any
from typing import Dict
from typing import List
from typing import Type
from typing import TypeVar
from typing import Union
from attrs import define as _attrs_define
from ..models.error import Error
from ..models.table_data_model import TableDataModel
from ..types import UNSET
from ..types import Unset
T = TypeVar("T", bound="Table")
[docs]
@_attrs_define
class Table:
"""Dataview summary
Attributes:
description (str):
errors (List['Error']):
name (str):
data_model (Union[Unset, TableDataModel]):
"""
description: str
errors: List["Error"]
name: str
data_model: Union[Unset, "TableDataModel"] = UNSET
[docs]
def to_dict(self) -> Dict[str, Any]:
"""Convert to a dict"""
description = self.description
errors = []
for errors_item_data in self.errors:
errors_item = errors_item_data.to_dict()
errors.append(errors_item)
name = self.name
data_model: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.data_model, Unset):
data_model = self.data_model.to_dict()
field_dict: Dict[str, Any] = {}
field_dict.update(
{
"description": description,
"errors": errors,
"name": name,
}
)
if data_model is not UNSET:
field_dict["data_model"] = data_model
return field_dict
[docs]
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
"""Create an instance of :py:class:`Table` from a dict"""
d = src_dict.copy()
description = d.pop("description")
errors = []
_errors = d.pop("errors")
for errors_item_data in _errors:
errors_item = Error.from_dict(errors_item_data)
errors.append(errors_item)
name = d.pop("name")
_data_model = d.pop("data_model", UNSET)
data_model: Union[Unset, TableDataModel]
if isinstance(_data_model, Unset):
data_model = UNSET
else:
data_model = TableDataModel.from_dict(_data_model)
table = cls(
description=description,
errors=errors,
name=name,
data_model=data_model,
)
return table