dataspecs.extras.formatting module#
- class Format(_format_id: ~typing.Annotated[str | ~os.PathLike[str], <Tag.ID: 1>], _format_of: ~typing.Annotated[~typing.Literal['id', 'tags', 'type', 'data', 'annotations', 'metadata', 'origin'], <Tag.OF: 2>] = 'data', _format_skipif: ~typing.Annotated[~typing.Any, <Tag.SKIPIF: 3>] = None)[source]#
Bases:
objectAnnotation for formatter specs.
- Parameters:
_format_id (Annotated[str | PathLike[str], <Tag.ID: 1>]) – ID of data spec(s) to be formatted.
_format_of (Annotated[Literal['id', 'tags', 'type', 'data', 'annotations', 'metadata', 'origin'], <Tag.OF: 2>]) – Name of data spec attribute to be formatted.
_format_skipif (Annotated[Any, <Tag.SKIPIF: 3>]) – Sentinel value for which formatting is skipped.
- format(specs: Specs[TSpec], /) Specs[TSpec][source]#
Format data spec attributes by formatter specs.
- Parameters:
specs (Specs[TSpec]) – Input data specs.
- Returns:
Data specs whose attributes are formatted.
- Return type:
Specs[TSpec]
Examples
from enum import auto from dataclasses import dataclass from dataspecs import TagBase, Format, from_dataclass, format from typing import Annotated as Ann class Tag(TagBase): ATTR = auto() @dataclass class Attrs: name: Ann[str, Tag.ATTR] units: Ann[str, Tag.ATTR] @dataclass class Weather: temp: Ann[list[float], Attrs("Temperature ({0})", "{0}")] units: Ann[str, Format("/temp/(name|units)")] = "degC" format(from_dataclass(Weather([20.0, 25.0], "K")))
Specs([ Spec( id=ID('/temp'), tags=(), type=list[float], data=[20.0, 25.0], ), Spec( id=ID('/temp/0'), tags=(), type=<class 'float'>, data=None, ), Spec( id=ID('/temp/name'), tags=(<Tag.ATTR: 1>,), type=<class 'str'>, data='Temperature (K)', # <- formatted ), Spec( id=ID('/temp/units'), tags=(<Tag.ATTR: 1>,), type=<class 'str'>, data='K', # <- formatted ), Spec( id=ID('/units'), tags=(), type=<class 'str'>, data='K', ), Spec( id=ID('/units/_format_id'), tags=(<Tag.ID: 1>,), type=<class 'str'>, data='/temp/attrs/(name|units)', ), Spec( id=ID('/units/_format_of'), tags=(<Tag.OF: 2>,), type=<class 'str'>, data='data', ), Spec( id=ID('/units/_format_skipif'), tags=(<Tag.SKIPIF: 3>,), type=typing.Any, data=None, ), ])