Source code for quantify_scheduler.helpers.importers

# Repository: https://gitlab.com/quantify-os/quantify-scheduler
# Licensed according to the LICENCE file on the main branch

import importlib
from typing import Any


[docs]def import_python_object_from_string(function_string: str) -> Any: """ Import a python object from a string This function does the inverse operation of :func:`export_python_object_to_path_string`. (Based on https://stackoverflow.com/questions/3061/calling-a-function-of-a-module-by-using-its-name-a-string) """ # pylint: disable=line-too-long mod_name, func_name = function_string.rsplit(".", 1) mod = importlib.import_module(mod_name) func = getattr(mod, func_name) return func
[docs]def export_python_object_to_path_string(obj: Any) -> str: """Get the absolute path (dot-separated) to a python object. This function does the inverse operation of :func:`import_python_object_from_string`. Parameters ---------- obj : Any Any python object. Returns ------- str A string containing a dot-separated absolute path to the object. """ module = obj.__module__ name = obj.__name__ if module == "__main__": path = name else: path = ".".join([module, name]) return path