labfreed 0.2.4__py3-none-any.whl → 0.2.5__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of labfreed might be problematic. Click here for more details.

Files changed (43) hide show
  1. labfreed/__init__.py +11 -11
  2. labfreed/labfreed_infrastructure.py +256 -256
  3. labfreed/pac_cat/__init__.py +19 -19
  4. labfreed/pac_cat/category_base.py +51 -51
  5. labfreed/pac_cat/pac_cat.py +150 -150
  6. labfreed/pac_cat/predefined_categories.py +200 -200
  7. labfreed/pac_id/__init__.py +19 -19
  8. labfreed/pac_id/extension.py +48 -48
  9. labfreed/pac_id/id_segment.py +89 -89
  10. labfreed/pac_id/pac_id.py +140 -140
  11. labfreed/pac_id/url_parser.py +153 -153
  12. labfreed/pac_id/url_serializer.py +80 -80
  13. labfreed/pac_id_resolver/__init__.py +2 -2
  14. labfreed/pac_id_resolver/cit_v1.py +150 -149
  15. labfreed/pac_id_resolver/cit_v2.py +303 -303
  16. labfreed/pac_id_resolver/resolver.py +86 -81
  17. labfreed/pac_id_resolver/services.py +79 -79
  18. labfreed/qr/__init__.py +1 -1
  19. labfreed/qr/generate_qr.py +422 -422
  20. labfreed/trex/__init__.py +16 -16
  21. labfreed/trex/python_convenience/__init__.py +3 -3
  22. labfreed/trex/python_convenience/data_table.py +87 -44
  23. labfreed/trex/python_convenience/pyTREX.py +248 -241
  24. labfreed/trex/python_convenience/quantity.py +66 -46
  25. labfreed/trex/table_segment.py +245 -244
  26. labfreed/trex/trex.py +69 -69
  27. labfreed/trex/trex_base_models.py +209 -210
  28. labfreed/trex/value_segments.py +99 -101
  29. labfreed/utilities/base36.py +82 -82
  30. labfreed/well_known_extensions/__init__.py +4 -4
  31. labfreed/well_known_extensions/default_extension_interpreters.py +6 -6
  32. labfreed/well_known_extensions/display_name_extension.py +40 -40
  33. labfreed/well_known_extensions/trex_extension.py +30 -30
  34. labfreed/well_known_keys/gs1/__init__.py +5 -5
  35. labfreed/well_known_keys/gs1/gs1.py +3 -3
  36. labfreed/well_known_keys/labfreed/well_known_keys.py +15 -15
  37. labfreed/well_known_keys/unece/__init__.py +3 -3
  38. labfreed/well_known_keys/unece/unece_units.py +67 -67
  39. {labfreed-0.2.4.dist-info → labfreed-0.2.5.dist-info}/METADATA +21 -9
  40. labfreed-0.2.5.dist-info/RECORD +44 -0
  41. {labfreed-0.2.4.dist-info → labfreed-0.2.5.dist-info}/licenses/LICENSE +21 -21
  42. labfreed-0.2.4.dist-info/RECORD +0 -44
  43. {labfreed-0.2.4.dist-info → labfreed-0.2.5.dist-info}/WHEEL +0 -0
labfreed/trex/__init__.py CHANGED
@@ -1,16 +1,16 @@
1
- from .trex import TREX
2
- from .value_segments import NumericSegment, DateSegment, BoolSegment, AlphanumericSegment, TextSegment, ErrorSegment
3
- from .table_segment import TableSegment, ColumnHeader, TableRow
4
-
5
- __all__ = [
6
- "TREX",
7
- "NumericSegment",
8
- "DateSegment",
9
- "BoolSegment",
10
- "AlphanumericSegment",
11
- "TextSegment",
12
- "ErrorSegment",
13
- "TableSegment",
14
- "ColumnHeader",
15
- "TableRow"
16
- ]
1
+ from .trex import TREX
2
+ from .value_segments import NumericSegment, DateSegment, BoolSegment, AlphanumericSegment, TextSegment, ErrorSegment
3
+ from .table_segment import TableSegment, ColumnHeader, TableRow
4
+
5
+ __all__ = [
6
+ "TREX",
7
+ "NumericSegment",
8
+ "DateSegment",
9
+ "BoolSegment",
10
+ "AlphanumericSegment",
11
+ "TextSegment",
12
+ "ErrorSegment",
13
+ "TableSegment",
14
+ "ColumnHeader",
15
+ "TableRow"
16
+ ]
@@ -1,3 +1,3 @@
1
- from .pyTREX import pyTREX # noqa: F401
2
- from .data_table import DataTable # noqa: F401
3
- from .quantity import Quantity # noqa: F401
1
+ from .pyTREX import pyTREX # noqa: F401
2
+ from .data_table import DataTable # noqa: F401
3
+ from .quantity import Quantity # noqa: F401
@@ -1,45 +1,88 @@
1
-
2
-
3
- from datetime import date, datetime, time
4
- from pydantic import BaseModel, Field, PrivateAttr
5
-
6
- from labfreed.utilities.base36 import base36
7
- from labfreed.trex.python_convenience.quantity import Quantity
8
-
9
-
10
- class DataTable(BaseModel):
11
- _row_template:list[str, Quantity | datetime | time | date | bool | str | base36] = PrivateAttr(default_factory=list)
12
- col_names: list[str] = Field(default_factory=list)
13
- data:list[Quantity | datetime | time | date | bool | str | base36] = Field(default_factory=list)
14
-
15
- @property
16
- def row_template(self):
17
- return self._row_template
18
-
19
- def append(self, row:list):
20
- if not isinstance(row, list):
21
- raise ValueError('row must be a list of values')
22
- if not self._row_template:
23
- self._row_template = row.copy()
24
- if not len(row) == len(self._row_template):
25
- raise ValueError('row is not of same length as the row template.')
26
- if not self.col_names:
27
- self.col_names = [f"Col{i}" for i in range(len(self._row_template))]
28
-
29
- # make sure int and float have a unit, if the row_tempalet has one
30
- for i, e in enumerate(row):
31
- if isinstance(e, float|int) and isinstance(self._row_template[i], Quantity):
32
- unit = self._row_template[i].unit
33
- row[i] = Quantity(value=e, unit=unit)
34
- self.data.append(row)
35
-
36
-
37
- def extend(self, iterable):
38
- for item in iterable:
39
- if not len(item) == len(self._row_template):
40
- raise ValueError('row is not of same length as the row template.')
41
- self.data.append(item)
42
-
43
-
44
-
1
+
2
+
3
+ from datetime import date, datetime, time
4
+ from typing import Union
5
+ from pydantic import BaseModel, Field, PrivateAttr, model_validator
6
+
7
+ from labfreed.utilities.base36 import base36
8
+ from labfreed.trex.python_convenience.quantity import Quantity
9
+
10
+
11
+ class DataTable(BaseModel):
12
+ _row_template:list[str, Quantity | datetime | time | date | bool | str | base36] = PrivateAttr(default_factory=list)
13
+ col_names: list[str] = Field(default_factory=list)
14
+ data:list[list[Union[Quantity, datetime, time, date, bool, str, base36, None]]] = Field(default_factory=list)
15
+
16
+ @property
17
+ def row_template(self):
18
+ return self._row_template
19
+
20
+ @model_validator(mode='after')
21
+ def get_row_template(self):
22
+ if not self.data: # data not initialized during construction. This is valid
23
+ return self
24
+
25
+ for r in self.data:
26
+ if all([e is not None for e in r]):
27
+ self._row_template = r.copy()
28
+ break
29
+ if not self._row_template:
30
+ raise ValueError('All columns contained at least one None. This is invalid')
31
+ return self
32
+
33
+
34
+ def append(self, row:list, validate=True):
35
+ if not isinstance(row, list):
36
+ raise ValueError('row must be a list of values')
37
+ if not self._row_template:
38
+ self._row_template = row.copy()
39
+ if not len(row) == len(self._row_template):
40
+ raise ValueError('row is not of same length as the row template.')
41
+ if not self.col_names:
42
+ self.col_names = [f"Col{i}" for i in range(len(self._row_template))]
43
+
44
+ # make sure int and float have a unit, if the row_tempalet has one
45
+ for i, e in enumerate(row):
46
+ if isinstance(e, float|int) and isinstance(self._row_template[i], Quantity):
47
+ unit = self._row_template[i].unit
48
+ row[i] = Quantity(value=e, unit=unit)
49
+ self.data.append(row)
50
+ if validate:
51
+ self.model_rebuild()
52
+
53
+
54
+ def extend(self, iterable):
55
+ for item in iterable:
56
+ if not len(item) == len(self._row_template):
57
+ raise ValueError('row is not of same length as the row template.')
58
+ self.append(item, validate=False)
59
+ self.model_rebuild()
60
+
61
+
62
+ def get_column(self, col:str|int) -> list:
63
+ if isinstance(col, str):
64
+ col_index = self.col_names.index(col)
65
+ else:
66
+ col_index = col
67
+ col_data = [row[col_index] for row in self.data]
68
+ return col_data
69
+
70
+
71
+ def get_row(self, row_index:int) -> list:
72
+ return self.data[row_index]
73
+
74
+
75
+ def get_row_as_dict(self, row_index:int) -> dict:
76
+ d = {k:v for k, v in zip(self.col_names, self.data[row_index])}
77
+ return d
78
+
79
+
80
+ def get_cell(self, row_index:int, col:str|int):
81
+ if isinstance(col, str):
82
+ col_index = self.col_names.index(col)
83
+ else:
84
+ col_index = col
85
+ return self.data[row_index][col_index]
86
+
87
+
45
88