dcicutils 8.16.6.1b1__tar.gz → 8.16.6.1b3__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/PKG-INFO +1 -1
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/data_readers.py +9 -2
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/structured_data.py +5 -7
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/pyproject.toml +1 -1
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/LICENSE.txt +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/README.rst +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/__init__.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/base.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/beanstalk_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/bundle_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/captured_output.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/cloudformation_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/codebuild_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/command_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/common.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/contribution_scripts.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/contribution_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/creds_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/data_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/datetime_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/deployment_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/diff_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/docker_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/ecr_scripts.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/ecr_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/ecs_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/env_base.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/env_manager.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/env_scripts.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/env_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/env_utils_legacy.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/es_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/exceptions.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/ff_mocks.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/ff_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/file_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/function_cache_decorator.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/glacier_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/hack_for_elasticsearch_numpy_usage.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/http_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/jh_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/kibana/dashboards.json +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/kibana/readme.md +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/lang_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/c4-infrastructure.jsonc +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/c4-python-infrastructure.jsonc +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-common-server.jsonc +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-common.jsonc +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-gpl-pipeline.jsonc +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-pipeline.jsonc +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/log_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/misc_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/obfuscation_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/opensearch_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/portal_object_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/portal_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/progress_bar.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/project_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/qa_checkers.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/qa_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/redis_tools.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/redis_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/s3_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/schema_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/scripts/publish_to_pypi.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/scripts/run_license_checker.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/scripts/update_portal_object.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/scripts/view_portal_object.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/secrets_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/sheet_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/snapshot_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/ssl_certificate_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/submitr/progress_constants.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/submitr/ref_lookup_strategy.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/task_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/tmpfile_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/trace_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/validation_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/variant_utils.py +0 -0
- {dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/zip_utils.py +0 -0
@@ -31,15 +31,22 @@ class RowReader(abc.ABC):
|
|
31
31
|
self.open()
|
32
32
|
|
33
33
|
def __iter__(self) -> Iterator:
|
34
|
+
header = self._iter_header()
|
34
35
|
for row in self.rows:
|
35
36
|
self.row_number += 1
|
36
37
|
if self.is_comment_row(row):
|
37
38
|
continue
|
38
39
|
if self.is_terminating_row(row):
|
39
40
|
break
|
40
|
-
if len(
|
41
|
+
if len(header) < len(row): # Row values beyond what there are headers for are ignored.
|
41
42
|
self._warning_extra_values.append(self.row_number)
|
42
|
-
yield {column: self.cell_value(value) for column, value in zip(
|
43
|
+
yield self._iter_mapper({column: self.cell_value(value) for column, value in zip(header, row)})
|
44
|
+
|
45
|
+
def _iter_header(self) -> List[str]:
|
46
|
+
return self.header
|
47
|
+
|
48
|
+
def _iter_mapper(self, row: dict) -> List[str]:
|
49
|
+
return row
|
43
50
|
|
44
51
|
def _define_header(self, header: List[Optional[Any]]) -> None:
|
45
52
|
self.header = []
|
@@ -59,7 +59,7 @@ class StructuredDataSet:
|
|
59
59
|
progress: Optional[Callable] = None,
|
60
60
|
validator_hook: Optional[Callable] = None,
|
61
61
|
validator_sheet_hook: Optional[Callable] = None,
|
62
|
-
|
62
|
+
excel_class: Optional[Excel] = None,
|
63
63
|
debug_sleep: Optional[str] = None) -> None:
|
64
64
|
self._progress = progress if callable(progress) else None
|
65
65
|
self._data = {}
|
@@ -80,7 +80,7 @@ class StructuredDataSet:
|
|
80
80
|
self._merge = True if merge is True else False # New merge functionality (2024-05-25)
|
81
81
|
self._validator_hook = validator_hook if callable(validator_hook) else None
|
82
82
|
self._validator_sheet_hook = validator_sheet_hook if callable(validator_sheet_hook) else None
|
83
|
-
self.
|
83
|
+
self._excel_class = excel_class if excel_class is not None and issubclass(excel_class, Excel) else Excel
|
84
84
|
self._debug_sleep = None
|
85
85
|
if debug_sleep:
|
86
86
|
try:
|
@@ -306,7 +306,7 @@ class StructuredDataSet:
|
|
306
306
|
def _load_excel_file(self, file: str) -> None:
|
307
307
|
def get_counts() -> Tuple[int, int]:
|
308
308
|
nonlocal file
|
309
|
-
excel =
|
309
|
+
excel = self._excel_class(file)
|
310
310
|
nrows = 0
|
311
311
|
for sheet_name in excel.sheet_names:
|
312
312
|
for row in excel.sheet_reader(sheet_name):
|
@@ -316,7 +316,8 @@ class StructuredDataSet:
|
|
316
316
|
nrows, nsheets = get_counts()
|
317
317
|
self._progress({PROGRESS.LOAD_START: PROGRESS.NOW(),
|
318
318
|
PROGRESS.LOAD_COUNT_SHEETS: nsheets, PROGRESS.LOAD_COUNT_ROWS: nrows})
|
319
|
-
excel =
|
319
|
+
excel = self._excel_class(file)
|
320
|
+
# Order the sheet names by any specified ordering (e.g. ala snovault.loadxl).
|
320
321
|
order = {Schema.type_name(key): index for index, key in enumerate(self._order)} if self._order else {}
|
321
322
|
for sheet_name in sorted(excel.sheet_names, key=lambda key: order.get(Schema.type_name(key), sys.maxsize)):
|
322
323
|
self._load_reader(excel.sheet_reader(sheet_name), type_name=Schema.type_name(sheet_name))
|
@@ -376,10 +377,7 @@ class StructuredDataSet:
|
|
376
377
|
schema = None
|
377
378
|
noschema = False
|
378
379
|
structured_row_template = None
|
379
|
-
sheet_name = reader.sheet_name if self._row_reader_mapper and hasattr(reader, "sheet_name") else None
|
380
380
|
for row in reader:
|
381
|
-
if self._row_reader_mapper and (not isinstance(row := self._row_reader_mapper(row, sheet_name), dict)):
|
382
|
-
continue
|
383
381
|
self._nrows += 1
|
384
382
|
if self._debug_sleep:
|
385
383
|
time.sleep(float(self._debug_sleep))
|
@@ -1,6 +1,6 @@
|
|
1
1
|
[tool.poetry]
|
2
2
|
name = "dcicutils"
|
3
|
-
version = "8.16.6.
|
3
|
+
version = "8.16.6.1b3" # TODO: 8.17.0
|
4
4
|
description = "Utility package for interacting with the 4DN Data Portal and other 4DN resources"
|
5
5
|
authors = ["4DN-DCIC Team <support@4dnucleome.org>"]
|
6
6
|
license = "MIT"
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/hack_for_elasticsearch_numpy_usage.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/c4-infrastructure.jsonc
RENAMED
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-common.jsonc
RENAMED
File without changes
|
{dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-gpl-pipeline.jsonc
RENAMED
File without changes
|
{dcicutils-8.16.6.1b1 → dcicutils-8.16.6.1b3}/dcicutils/license_policies/park-lab-pipeline.jsonc
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|