libera_utils.io.filenaming.AttitudeKernelFilename#
- class libera_utils.io.filenaming.AttitudeKernelFilename(*args, **kwargs)#
Bases:
AbstractValidFilename
Class to construct, store, and manipulate an SPK filename
- Attributes:
archive_prefix
Property that contains the generated prefix for SPICE archiving
filename_parts
Property that contains a namespace of filename parts
path
Property containing the file path
Methods
from_filename_parts
([basepath, ck_object, ...])Create instance from filename parts.
generate_prefixed_path
(parent_path)Generates an absolute path of the form {parent_path}/{prefix_structure}/{file_basename} The parent_path can be an S3 bucket or an absolute local filepath (must start with /)
regex_match
(path)Parse and validate a given path against class-attribute defined regex
- __init__(*args, **kwargs)#
Methods
from_filename_parts
([basepath, ck_object, ...])Create instance from filename parts.
generate_prefixed_path
(parent_path)Generates an absolute path of the form {parent_path}/{prefix_structure}/{file_basename} The parent_path can be an S3 bucket or an absolute local filepath (must start with /)
regex_match
(path)Parse and validate a given path against class-attribute defined regex
Attributes
Property that contains the generated prefix for SPICE archiving
Property that contains a namespace of filename parts
Property containing the file path
- static _calculate_applicable_time(start: datetime, end: datetime)#
Based on the start time and end time of a file, returns the applicable time (date)
- Parameters:
start (datetime.datetime) – Start of the applicable time range
end (datetime.datetime) – End of the applicable time range
- Returns:
The date of the mean time between start and end
- Return type:
- classmethod _check_required_parts(local_vars: dict)#
Checks for the presence of required filename parts
- Parameters:
local_vars (dict) – Dictionary of variables passed, created by a call to locals()
- classmethod _format_filename_parts(ck_object: str, version: str, utc_start: datetime, utc_end: datetime, revision: datetime)#
Format filename parts as a string
- Parameters:
ck_object (str) – Name of object whose attitude is represented in this CK.
utc_start (datetime.datetime) – Start time of data.
utc_end (datetime.datetime) – End time of data.
version (str) – Software version that the file was created with. Corresponds to the algorithm version as determined by the algorithm software.
revision (datetime.datetime) – When the file was last revised.
- Return type:
- classmethod _from_filename_parts(basepath: str = None, **parts)#
Create instance from filename parts.
The part arg names are named according to the regex for the file type.
- Parameters:
basepath (str or pathlib.Path, Optional) – Allows prepending a basepath or prefix.
parts (dict) – Passed directly to _format_filename_parts
- Return type:
- _parse_filename_parts()#
Parse the filename parts into objects from regex matched strings
- Returns:
namespace object containing filename parts as parsed objects
- Return type:
- property archive_prefix#
Property that contains the generated prefix for SPICE archiving
- property filename_parts#
Property that contains a namespace of filename parts
- classmethod from_filename_parts(basepath: str = None, ck_object: str = None, version: str = None, utc_start: datetime = None, utc_end: datetime = None, revision: datetime = None)#
Create instance from filename parts. All keyword arguments other than basepath are required!
The part arg names are named according to the regex for the file type.
- Parameters:
basepath (str or pathlib.Path, Optional) – Allows prepending a basepath or prefix.
ck_object (str) – Name of object whose attitude is represented in this CK.
version (str) – Software version that the file was created with. Corresponds to the algorithm version as determined by the algorithm software.
utc_start (datetime.datetime) – Start time of data.
utc_end (datetime.datetime) – End time of data.
revision (datetime.datetime) – When the file was last revised.
- Return type:
- generate_prefixed_path(parent_path: str | Path | S3Path) Path | S3Path #
Generates an absolute path of the form {parent_path}/{prefix_structure}/{file_basename} The parent_path can be an S3 bucket or an absolute local filepath (must start with /)
- Parameters:
parent_path (str or pathlib.Path or cloudpathlib.s3.s3path.S3Path) – Absolute path to the parent directory or S3 bucket prefix. The generated path prefix is appended to the parent path and followed by the file basename.
- Return type:
- property path#
Property containing the file path