|
| 1 | +""" |
| 2 | +Contains Tagesvektor class and corresponding marshmallow schema for de-/serialization |
| 3 | +""" |
| 4 | +import datetime |
| 5 | +from typing import List |
| 6 | + |
| 7 | +import attr |
| 8 | +from marshmallow import fields, post_load |
| 9 | + |
| 10 | +from bo4e.com.com import COM, COMSchema |
| 11 | +from bo4e.com.zeitreihenwertkompakt import Zeitreihenwertkompakt, ZeitreihenwertkompaktSchema |
| 12 | + |
| 13 | + |
| 14 | +# pylint: disable=too-few-public-methods |
| 15 | +from bo4e.validators import check_list_length_at_least_one |
| 16 | + |
| 17 | + |
| 18 | +@attr.s(auto_attribs=True, kw_only=True) |
| 19 | +class Tagesvektor(COM): |
| 20 | + """ |
| 21 | + Abbildung eines Tagesvektors eines beliebigen äquidistanten Zeitrasters |
| 22 | + """ |
| 23 | + |
| 24 | + # required attributes |
| 25 | + # for the validator see https://github.com/Hochfrequenz/BO4E-python/issues/261 |
| 26 | + tag: datetime.datetime = attr.ib(validator=attr.validators.instance_of(datetime.datetime)) |
| 27 | + """ |
| 28 | + Der Zeitpunkt ab dem die Werte ermittelt wurden. |
| 29 | + Es kann entweder der Beginn des Strom- oder Gastages verwendet werden. |
| 30 | + Der Zeitpunkt sollte eindeutig sein, d.h. sowohl Datum+Uhrzeit als auch den UTC-Offset spezifizieren. |
| 31 | + """ |
| 32 | + # for the validator see also https://github.com/Hochfrequenz/BO4E-python/issues/262 |
| 33 | + # https://www.attrs.org/en/stable/api.html#attr.validators.deep_iterable |
| 34 | + werte: List[Zeitreihenwertkompakt] = attr.ib( |
| 35 | + validator=[ |
| 36 | + attr.validators.deep_iterable( |
| 37 | + member_validator=attr.validators.instance_of(Zeitreihenwertkompakt), |
| 38 | + iterable_validator=attr.validators.instance_of(list), |
| 39 | + ), |
| 40 | + check_list_length_at_least_one, |
| 41 | + ] |
| 42 | + ) |
| 43 | + """ |
| 44 | + Die Werte am angegebenen Tag; |
| 45 | + In Kombination aus Zeitintervall und Tag lassen sich die Zeiten der Werte eindeutig konstruieren. |
| 46 | + """ |
| 47 | + |
| 48 | + |
| 49 | +class TagesvektorSchema(COMSchema): |
| 50 | + """ |
| 51 | + Schema for de-/serialization of Tagesvektor |
| 52 | + """ |
| 53 | + |
| 54 | + # required attributes |
| 55 | + tag = fields.DateTime() |
| 56 | + werte = fields.List(fields.Nested(ZeitreihenwertkompaktSchema)) |
| 57 | + |
| 58 | + # pylint: disable=no-self-use, unused-argument |
| 59 | + @post_load |
| 60 | + def deserialize(self, data, **kwargs) -> Tagesvektor: |
| 61 | + """Deserialize JSON to Preisstaffel object""" |
| 62 | + return Tagesvektor(**data) |
0 commit comments