Source code for modos.io
from dataclasses import dataclass
from pathlib import Path
import re
from typing import List, Optional
from linkml_runtime.loaders import (
json_loader,
yaml_loader,
csv_loader,
rdf_loader,
)
import modos_schema.datamodel as model
import zarr
import modos.genomics.cram as cram
import modos.metabolomics.mztab as mztab
from modos.helpers.schema import dict_to_instance
[docs]
ext2loader = {
"json": json_loader,
r"ya?ml": yaml_loader,
"csv": csv_loader,
r"rdf|ttl|nt(riples)?": rdf_loader,
}
[docs]
def get_loader(path: Path):
"""Get a loader based on the file extension using regex."""
ext = path.suffix[1:]
for pattern, loader in ext2loader.items():
if re.match(pattern, ext):
return loader
return None
[docs]
def parse_instance(path: Path, target_class):
"""Load a model of target_class from a file."""
loader = get_loader(path)
if not loader:
raise ValueError(f"Unsupported file format: {path}")
return loader.load(str(path), target_class)
[docs]
def parse_attributes(path: Path) -> List[dict]:
"""Load model specification from file into a list of dictionaries. Model types must be specified as @type"""
loader = get_loader(path)
if not loader:
raise ValueError(f"Unsupported file format: {path}")
elems = loader.load_as_dict(str(path))
if not isinstance(elems, list):
elems = [elems]
return elems
[docs]
def parse_multiple_instances(path: Path) -> List:
"""Load one or more model from file. Model types must be specified as @type"""
elems = parse_attributes(path)
instances = []
for elem in elems:
instances.append(dict_to_instance(elem))
return instances
@dataclass