1234567891011121314151617181920212223242526272829303132 |
- import logging
- from typing import Any
- import yaml
- from yaml import YAMLError
- logger = logging.getLogger(__name__)
- def load_yaml_file(file_path: str, ignore_error: bool = True, default_value: Any = {}) -> Any:
- """
- Safe loading a YAML file
- :param file_path: the path of the YAML file
- :param ignore_error:
- if True, return default_value if error occurs and the error will be logged in debug level
- if False, raise error if error occurs
- :param default_value: the value returned when errors ignored
- :return: an object of the YAML content
- """
- try:
- with open(file_path, encoding='utf-8') as yaml_file:
- try:
- yaml_content = yaml.safe_load(yaml_file)
- return yaml_content if yaml_content else default_value
- except Exception as e:
- raise YAMLError(f'Failed to load YAML file {file_path}: {e}')
- except Exception as e:
- if ignore_error:
- logger.debug(f'Failed to load YAML file {file_path}: {e}')
- return default_value
- else:
- raise e
|