Source code for oasislmf.pytools.converters.bintocsv.utils.coverages

from pathlib import Path
import numpy as np
from oasislmf.pytools.common.data import write_ndarray_to_fmt_csv
from oasislmf.pytools.common.input_files import read_coverages
from oasislmf.pytools.converters.data import TOOL_INFO


[docs] def coverages_tocsv(stack, file_in, file_out, file_type, noheader): headers = TOOL_INFO[file_type]["headers"] dtype = TOOL_INFO[file_type]["dtype"] fmt = TOOL_INFO[file_type]["fmt"] if str(file_in) == "-": coverages = read_coverages( ignore_file_type=set(["csv"]), use_stdin=True ) else: cov_fp = Path(file_in) coverages = read_coverages( run_dir=cov_fp.parent, ignore_file_type=set(["csv"]), filename=cov_fp.name ) data = np.zeros(len(coverages), dtype=dtype) data["coverage_id"] = np.arange(1, len(coverages) + 1) data["tiv"] = coverages if not noheader: file_out.write(",".join(headers) + "\n") write_ndarray_to_fmt_csv(file_out, data, headers, fmt)