From 65a6b142a625c258da2e67c0f736b35ebfcfbd7e Mon Sep 17 00:00:00 2001 From: sharkinsspatial Date: Mon, 18 Nov 2024 14:59:46 -0500 Subject: [PATCH] Handle use of soft import sub modules for typing. --- virtualizarr/readers/hdf/filters.py | 12 ++++++++-- virtualizarr/readers/hdf/hdf.py | 37 +++++++++++++---------------- 2 files changed, 26 insertions(+), 23 deletions(-) diff --git a/virtualizarr/readers/hdf/filters.py b/virtualizarr/readers/hdf/filters.py index bf50f836..f0d1e8eb 100644 --- a/virtualizarr/readers/hdf/filters.py +++ b/virtualizarr/readers/hdf/filters.py @@ -11,8 +11,16 @@ if TYPE_CHECKING: import h5py # type: ignore + from h5py import Dataset, Group # type: ignore h5py = soft_import("h5py", "For reading hdf files", strict=False) +if h5py: + Dataset = h5py.Dataset + Group = h5py.Group +else: + Dataset = dict() + Group = dict() + hdf5plugin = soft_import( "hdf5plugin", "For reading hdf files with filters", strict=False ) @@ -119,7 +127,7 @@ def _filter_to_codec( return codec -def cfcodec_from_dataset(dataset: h5py.Dataset) -> Codec | None: +def cfcodec_from_dataset(dataset: Dataset) -> Codec | None: """ Converts select h5py dataset CF convention attrs to CFCodec @@ -166,7 +174,7 @@ def cfcodec_from_dataset(dataset: h5py.Dataset) -> Codec | None: return None -def codecs_from_dataset(dataset: h5py.Dataset) -> List[Codec]: +def codecs_from_dataset(dataset: Dataset) -> List[Codec]: """ Extracts a list of numcodecs from an h5py dataset diff --git a/virtualizarr/readers/hdf/hdf.py b/virtualizarr/readers/hdf/hdf.py index a942268c..0eee63d5 100644 --- a/virtualizarr/readers/hdf/hdf.py +++ b/virtualizarr/readers/hdf/hdf.py @@ -1,9 +1,9 @@ import math -from dataclasses import dataclass from typing import TYPE_CHECKING, Dict, Iterable, List, Mapping, Optional, Union import numpy as np -from xarray import Dataset, Index, Variable +import xarray as xr +from xarray import Index, Variable from virtualizarr.manifests import ChunkEntry, ChunkManifest, ManifestArray from virtualizarr.readers.common import ( @@ -18,18 +18,15 @@ if TYPE_CHECKING: import h5py # type: ignore - + from h5py import Dataset, Group # type: ignore h5py = soft_import("h5py", "For reading hdf files", strict=False) - -if not h5py: - - @dataclass - class h5py_stub: - Group: str - Dataset: str - - h5py = h5py_stub(Group="", Dataset="") +if h5py: + Dataset = h5py.Dataset + Group = h5py.Group +else: + Dataset = dict() + Group = dict() class HDFVirtualBackend(VirtualBackend): @@ -42,7 +39,7 @@ def open_virtual_dataset( decode_times: bool | None = None, indexes: Mapping[str, Index] | None = None, reader_options: Optional[dict] = None, - ) -> Dataset: + ) -> xr.Dataset: drop_variables, loadable_variables = check_for_collisions( drop_variables, loadable_variables, @@ -79,9 +76,7 @@ def open_virtual_dataset( ) @staticmethod - def _dataset_chunk_manifest( - path: str, dataset: h5py.Dataset - ) -> Optional[ChunkManifest]: + def _dataset_chunk_manifest(path: str, dataset: Dataset) -> Optional[ChunkManifest]: """ Generate ChunkManifest for HDF5 dataset. @@ -148,7 +143,7 @@ def add_chunk_info(blob): return chunk_manifest @staticmethod - def _dataset_dims(dataset: h5py.Dataset) -> Union[List[str], List[None]]: + def _dataset_dims(dataset: Dataset) -> Union[List[str], List[None]]: """ Get a list of dimension scale names attached to input HDF5 dataset. @@ -190,14 +185,14 @@ def _dataset_dims(dataset: h5py.Dataset) -> Union[List[str], List[None]]: return dims @staticmethod - def _extract_attrs(h5obj: Union[h5py.Dataset, h5py.Group]): + def _extract_attrs(h5obj: Union[Dataset, Group]): """ Extract attributes from an HDF5 group or dataset. Parameters ---------- h5obj : h5py.Group or h5py.Dataset - An HDF5 group or dataset. + An h5py group or dataset. """ _HIDDEN_ATTRS = { "REFERENCE_LIST", @@ -236,7 +231,7 @@ def _extract_attrs(h5obj: Union[h5py.Dataset, h5py.Group]): return attrs @staticmethod - def _dataset_to_variable(path: str, dataset: h5py.Dataset) -> Optional[Variable]: + def _dataset_to_variable(path: str, dataset: Dataset) -> Optional[Variable]: """ Extract an xarray Variable with ManifestArray data from an h5py dataset @@ -338,7 +333,7 @@ def _virtual_vars_from_hdf( variables = {} for key in g.keys(): if key not in drop_variables: - if isinstance(g[key], h5py.Dataset): + if isinstance(g[key], Dataset): variable = HDFVirtualBackend._dataset_to_variable(path, g[key]) if variable is not None: variables[key] = variable