Source code for capytaine.tools.optional_imports

"""Tool to import optional dependencies. Inspired by similar code in pandas."""

import importlib

[docs] def import_optional_dependency( module_name: str, package_name: str = None, error_message: str = None, ): """Return an imported module or raises an error. The error message can be customized either by passing the name of the package to install (if it's different from the module name), or by passing a full error message.""" try: module = importlib.import_module(module_name) except ImportError: if error_message is None: if package_name is None: package_name = module_name error_message = ( f"Missing optional dependency '{module_name}'. " f"Use pip or conda to install {package_name}." ) raise ImportError(error_message) from None return module
[docs] def silently_import_optional_dependency(module_name: str): # Same as above, except it does not raise a exception when the module is not found. # Instead, simply returns None. try: module = importlib.import_module(module_name) except ImportError: module = None return module