OwlMixin

Note

Usage on each methods are valid on the premise that the following classes is defined in advance.

# coding: utf-8

from owlmixin import OwlMixin, TOption
from owlmixin.owlcollections import TDict, TList
from owlmixin.owlenum import OwlEnum, OwlObjectEnum


class Animal(OwlObjectEnum):  # pragma: no cover
    DOG = ("dog", {"cry": "bow-wow"})
    CAT = ("cat", {"cry": "mewing"})

    def cry(self):
        return self.object["cry"]


class Color(OwlEnum):  # pragma: no cover
    RED = "red"
    GREEN = "green"
    BLUE = "blue"


class Food(OwlMixin):  # pragma: no cover
    name: str
    names_by_lang: TOption[TDict[str]]


class Human(OwlMixin):  # pragma: no cover
    id: int
    name: str
    favorites: TList[Food]


class Machine(OwlMixin):  # pragma: no cover
    id: int
    name: str


class Japanese(OwlMixin):  # pragma: no cover
    name: str
    language: str = "japanese"
class owlmixin.OwlMixin[source]
classmethod from_dict(d: dict, *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) T[source]

From dict to instance

Parameters:
  • d – Dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

Usage:

>>> from owlmixin.samples import Human, Food, Japanese
>>> human: Human = Human.from_dict({
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple", "de": "Apfel"}},
...         {"name": "Orange"}
...     ]
... })
>>> human.id
1
>>> human.name
'Tom'
>>> human.favorites[0].name
'Apple'
>>> human.favorites[0].names_by_lang.get()["de"]
'Apfel'

You can use default value

>>> taro: Japanese = Japanese.from_dict({
...     "name": 'taro'
... })  
>>> taro.name
'taro'
>>> taro.language
'japanese'

If you don’t set force_snake=False explicitly, keys are transformed to snake case as following.

>>> human: Human = Human.from_dict({
...     "--id": 1,
...     "<name>": "Tom",
...     "favorites": [
...         {"name": "Apple", "namesByLang": {"en": "Apple"}}
...     ]
... })
>>> human.id
1
>>> human.name
'Tom'
>>> human.favorites[0].names_by_lang.get()["en"]
'Apple'

You can allow extra parameters (like hogehoge) if you set restrict=False.

>>> apple: Food = Food.from_dict({
...     "name": "Apple",
...     "hogehoge": "ooooooooooooooooooooo",
... }, restrict=False)
>>> apple.to_dict()
{'name': 'Apple'}

You can prohibit extra parameters (like hogehoge) if you set restrict=True (which is default).

>>> human = Human.from_dict({
...     "id": 1,
...     "name": "Tom",
...     "hogehoge1": "ooooooooooooooooooooo",
...     "hogehoge2": ["aaaaaaaaaaaaaaaaaa", "iiiiiiiiiiiiiiiii"],
...     "favorites": [
...         {"name": "Apple", "namesByLang": {"en": "Apple", "de": "Apfel"}},
...         {"name": "Orange"}
...     ]
... })  
Traceback (most recent call last):
    ...
owlmixin.errors.UnknownPropertiesError:
.        ∧,,_∧      ,___________________
     ⊂ ( ・ω・ )つ-  <  Unknown properties error
   ///     /::/     `-------------------
   |::|/⊂ヽノ|::|」
/ ̄ ̄旦 ̄ ̄ ̄/|
______/  | |
|------ー----ー|/

`owlmixin.samples.Human` has unknown properties ['hogehoge1', 'hogehoge2']!!

    * If you want to allow unknown properties, set `restrict=False`
    * If you want to disallow unknown properties, add `hogehoge1` and `hogehoge2` to owlmixin.samples.Human

If you specify wrong type…

>>> human: Human = Human.from_dict({
...     "id": 1,
...     "name": "ichiro",
...     "favorites": ["apple", "orange"]
... })  
Traceback (most recent call last):
    ...
owlmixin.errors.InvalidTypeError:
.        ∧,,_∧      ,___________________
     ⊂ ( ・ω・ )つ-  <  Invalid Type error
   ///     /::/     `-------------------
   |::|/⊂ヽノ|::|」
/ ̄ ̄旦 ̄ ̄ ̄/|
______/  | |
|------ー----ー|/

`owlmixin.samples.Human#favorites.0 = apple` doesn't match expected types.
Expected type is one of ["<class 'owlmixin.samples.Food'>", "<class 'dict'>"], but actual type is `<class 'str'>`

    * If you want to force cast, set `force_cast=True`
    * If you don't want to force cast, specify value which has correct type

If you don’t specify required params… (ex. name

>>> human: Human = Human.from_dict({
...     "id": 1
... })  
Traceback (most recent call last):
    ...
owlmixin.errors.RequiredError:
.        ∧,,_∧      ,___________________
     ⊂ ( ・ω・ )つ-  <  Required error
   ///     /::/     `-------------------
   |::|/⊂ヽノ|::|」
/ ̄ ̄旦 ̄ ̄ ̄/|
______/  | |
|------ー----ー|/

`owlmixin.samples.Human#name: <class 'str'>` is empty!!

    * If `name` is certainly required, specify anything.
    * If `name` is optional, change type from `<class 'str'>` to `TOption[<class 'str'>]`
classmethod from_optional_dict(d: dict | None, *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) TOption[T][source]

From dict to optional instance.

Parameters:
  • d – Dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

Usage:

>>> from owlmixin.samples import Human
>>> Human.from_optional_dict(None).is_none()
True
>>> Human.from_optional_dict({}).get()  
Traceback (most recent call last):
    ...
owlmixin.errors.RequiredError:
.        ∧,,_∧      ,___________________
     ⊂ ( ・ω・ )つ-  <  Required error
   ///     /::/     `-------------------
   |::|/⊂ヽノ|::|」
/ ̄ ̄旦 ̄ ̄ ̄/|
______/  | |
|------ー----ー|/

`owlmixin.samples.Human#id: <class 'int'>` is empty!!

    * If `id` is certainly required, specify anything.
    * If `id` is optional, change type from `<class 'int'>` to `TOption[<class 'int'>]`
classmethod from_dicts(ds: List[dict], *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) TList[T][source]

From list of dict to list of instance

Parameters:
  • ds – List of dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

List of instance

Usage:

>>> from owlmixin.samples import Human
>>> humans: TList[Human] = Human.from_dicts([
...    {"id": 1, "name": "Tom", "favorites": [{"name": "Apple"}]},
...    {"id": 2, "name": "John", "favorites": [{"name": "Orange"}]}
... ])
>>> humans[0].name
'Tom'
>>> humans[1].name
'John'
classmethod from_iterable_dicts(ds: Iterable[dict], *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) TIterator[T][source]

From iterable dict to iterable instance

Parameters:
  • ds – Iterable dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterator

Usage:

>>> from owlmixin.samples import Human
>>> humans: TIterator[Human] = Human.from_iterable_dicts([
...    {"id": 1, "name": "Tom", "favorites": [{"name": "Apple"}]},
...    {"id": 2, "name": "John", "favorites": [{"name": "Orange"}]}
... ])
>>> humans.next_at(0).get().name
'Tom'
>>> humans.next_at(0).get().name
'John'
classmethod from_optional_dicts(ds: List[dict] | None, *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) TOption[TList[T]][source]

From list of dict to optional list of instance.

Parameters:
  • ds – List of dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

List of instance

Usage:

>>> from owlmixin.samples import Human
>>> Human.from_optional_dicts(None).is_none()
True
>>> Human.from_optional_dicts([]).get()
[]
classmethod from_optional_iterable_dicts(ds: Iterable[dict] | None, *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) TOption[TIterator[T]][source]

From iterable dict to optional iterable instance.

Parameters:
  • ds – Iterable dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterable instance

Usage:

>>> from owlmixin.samples import Human
>>> Human.from_optional_dicts(None).is_none()
True
>>> Human.from_optional_dicts([]).get()
[]
classmethod from_dicts_by_key(ds: dict, *, force_snake_case: bool = True, force_cast: bool = False, restrict: bool = True) TDict[T][source]

From dict of dict to dict of instance

Parameters:
  • ds – Dict of dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Dict of instance

Usage:

>>> from owlmixin.samples import Human
>>> humans_by_name: TDict[Human] = Human.from_dicts_by_key({
...    'Tom':  {"id": 1, "name": "Tom",  "favorites": [{"name": "Apple"}]},
...    'John': {"id": 2, "name": "John", "favorites": [{"name": "Orange"}]}
... })
>>> humans_by_name['Tom'].name
'Tom'
>>> humans_by_name['John'].name
'John'
classmethod from_optional_dicts_by_key(ds: dict | None, *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) TOption[TDict[T]][source]

From dict of dict to optional dict of instance.

Parameters:
  • ds – Dict of dict

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Dict of instance

Usage:

>>> from owlmixin.samples import Human
>>> Human.from_optional_dicts_by_key(None).is_none()
True
>>> Human.from_optional_dicts_by_key({}).get()
{}
classmethod from_json(data: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) T[source]

From json string to instance

Parameters:
  • data – Json string

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

Usage:

>>> from owlmixin.samples import Human
>>> human: Human = Human.from_json('''{
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple", "de": "Apfel"}},
...         {"name": "Orange"}
...     ]
... }''')
>>> human.id
1
>>> human.name
'Tom'
>>> human.favorites[0].names_by_lang.get()["de"]
'Apfel'
classmethod from_jsonf(fpath: str, encoding: str = 'utf8', *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) T[source]

From json file path to instance

Parameters:
  • fpath – Json file path

  • encoding – Json file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

classmethod from_json_to_list(data: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) TList[T][source]

From json string to list of instance

Parameters:
  • data – Json string

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

List of instance

Usage:

>>> from owlmixin.samples import Human
>>> humans: TList[Human] = Human.from_json_to_list('''[
...    {"id": 1, "name": "Tom",  "favorites": [{"name": "Apple"}]},
...    {"id": 2, "name": "John", "favorites": [{"name": "Orange"}]}
... ]''')
>>> humans[0].name
'Tom'
>>> humans[1].name
'John'
classmethod from_json_to_iterator(data: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) TIterator[T][source]

From json string to iterable instance

Parameters:
  • data – Json string

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterable instance

Usage:

>>> from owlmixin.samples import Human
>>> humans: TIterator[Human] = Human.from_json_to_iterator('''[
...    {"id": 1, "name": "Tom",  "favorites": [{"name": "Apple"}]},
...    {"id": 2, "name": "John", "favorites": [{"name": "Orange"}]}
... ]''')
>>> humans.next_at(1).get().name
'John'
>>> humans.next_at(0).is_none()
True
classmethod from_jsonf_to_list(fpath: str, encoding: str = 'utf8', *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) TList[T][source]

From json file path to list of instance

Parameters:
  • fpath – Json file path

  • encoding – Json file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

List of instance

classmethod from_jsonf_to_iterator(fpath: str, encoding: str = 'utf8', *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) TIterator[T][source]

From json file path to iterable instance

Parameters:
  • fpath – Json file path

  • encoding – Json file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterable instance

classmethod from_yaml(data: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) T[source]

From yaml string to instance

Parameters:
  • data – Yaml string

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

Usage:

>>> from owlmixin.samples import Human
>>> human: Human = Human.from_yaml('''
... id: 1
... name: Tom
... favorites:
...   - name: Apple
...     names_by_lang:
...       en: Apple
...       de: Apfel
...   - name: Orange
... ''')
>>> human.id
1
>>> human.name
'Tom'
>>> human.favorites[0].names_by_lang.get()["de"]
'Apfel'
classmethod from_yamlf(fpath: str, encoding: str = 'utf8', *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) T[source]

From yaml file path to instance

Parameters:
  • fpath – Yaml file path

  • encoding – Yaml file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

classmethod from_yaml_to_list(data: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) TList[T][source]

From yaml string to list of instance

Parameters:
  • data – Yaml string

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

List of instance

Usage:

>>> from owlmixin.samples import Human
>>> humans: TList[Human] = Human.from_yaml_to_list('''
... - id: 1
...   name: Tom
...   favorites:
...     - name: Apple
... - id: 2
...   name: John
...   favorites:
...     - name: Orange
... ''')
>>> humans[0].name
'Tom'
>>> humans[1].name
'John'
>>> humans[0].favorites[0].name
'Apple'
classmethod from_yaml_to_iterator(data: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) TIterator[T][source]

From yaml string to iterable instance

Parameters:
  • data – Yaml string

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterable instance

Usage:

>>> from owlmixin.samples import Human
>>> humans: TIterator[Human] = Human.from_yaml_to_iterator('''
... - id: 1
...   name: Tom
...   favorites:
...     - name: Apple
... - id: 2
...   name: John
...   favorites:
...     - name: Orange
... ''')
>>> human1 = humans.next_at(1).get()
>>> human1.name
'John'
>>> humans.next_at(0).is_none()
True
>>> human1.favorites[0].name
'Orange'
classmethod from_yamlf_to_list(fpath: str, encoding: str = 'utf8', *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) TList[T][source]

From yaml file path to list of instance

Parameters:
  • fpath – Yaml file path

  • encoding – Yaml file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

List of instance

classmethod from_yamlf_to_iterator(fpath: str, encoding: str = 'utf8', *, force_snake_case=True, force_cast: bool = False, restrict: bool = True) TIterator[T][source]

From yaml file path to iterable instance

Parameters:
  • fpath – Yaml file path

  • encoding – Yaml file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterable instance

classmethod from_csvf_to_list(fpath: str, fieldnames: Sequence[str] | None = None, encoding: str = 'utf8', *, force_snake_case: bool = True, restrict: bool = True) TList[T][source]

From csv file path to list of instance

Parameters:
  • fpath – Csv file path

  • fieldnames – Specify csv header names if not included in the file

  • encoding – Csv file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • restrict – Prohibit extra parameters if True

Returns:

List of Instance

classmethod from_csvf_to_iterator(fpath: str, fieldnames: Sequence[str] | None = None, encoding: str = 'utf8', *, force_snake_case: bool = True, restrict: bool = True) TIterator[T][source]

From csv file path to iterable instance

Parameters:
  • fpath – Csv file path

  • fieldnames – Specify csv header names if not included in the file

  • encoding – Csv file encoding

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • restrict – Prohibit extra parameters if True

Returns:

Iterable Instance

classmethod from_json_url(url: str, *, force_snake_case=True, force_cast: bool = False, restrict: bool = False) T[source]

From url which returns json to instance

Parameters:
  • url – Url which returns json

  • force_snake_case – Keys are transformed to snake case in order to compliant PEP8 if True

  • force_cast – Cast forcibly if True

  • restrict – Prohibit extra parameters if True

Returns:

Instance

str_format(format_: str) str

From instance to str with formatting

Parameters:

format – format string

Returns:

str

Usage:

>>> from owlmixin.samples import Human, Food
>>> human_dict = {
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple"}}
...     ]
... }
>>> Human.from_dict(human_dict).str_format('{id}: {name}')
'1: Tom'
to_dict(*, ignore_none: bool = True, force_value: bool = True, ignore_empty: bool = False) dict

From instance to dict

Parameters:
  • ignore_none – Properties which is None are excluded if True

  • force_value – Transform to value using to_value (default: str()) of ValueTransformer which inherited if True

  • ignore_empty – Properties which is empty are excluded if True

Returns:

Dict

Usage:
>>> from owlmixin.samples import Human, Food
>>> human_dict = {
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple"}}
...     ]
... }
>>> Human.from_dict(human_dict).to_dict() == human_dict
True

You can include None properties by specifying False for ignore_none

>>> f = Food.from_dict({"name": "Apple"}).to_dict(ignore_none=False)
>>> f["name"]
'Apple'
>>> "names_by_lang" in f
True
>>> f["names_by_lang"]

As default

>>> f = Food.from_dict({"name": "Apple"}).to_dict()
>>> f["name"]
'Apple'
>>> "names_by_lang" in f
False

You can exclude Empty properties by specifying True for ignore_empty

>>> f = Human.from_dict({"id": 1, "name": "Ichiro", "favorites": []}).to_dict()
>>> f["favorites"]
[]
>>> f = Human.from_dict({"id": 1, "name": "Ichiro", "favorites": []}).to_dict(ignore_empty=True)
>>> "favorites" in f
False
to_json(*, indent: int = None, ignore_none: bool = True, ignore_empty: bool = False) str

From instance to json string

Parameters:
  • indent – Number of indentation

  • ignore_none – Properties which is None are excluded if True

  • ignore_empty – Properties which is empty are excluded if True

Returns:

Json string

Usage:

>>> from owlmixin.samples import Human
>>> human = Human.from_dict({
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple", "de": "Apfel"}},
...         {"name": "Orange"}
...     ]
... })
>>> human.to_json()
'{"favorites": [{"name": "Apple","names_by_lang": {"de": "Apfel","en": "Apple"}},{"name": "Orange"}],"id": 1,"name": "Tom"}'
to_jsonf(fpath: str, encoding: str = 'utf8', *, indent: int = None, ignore_none: bool = True, ignore_empty: bool = False) str

From instance to json file

Parameters:
  • fpath – Json file path

  • encoding – Json file encoding

  • indent – Number of indentation

  • ignore_none – Properties which is None are excluded if True

  • ignore_empty – Properties which is empty are excluded if True

Returns:

Json file path

to_pretty_json(*, ignore_none: bool = True, ignore_empty: bool = False) str

From instance to pretty json string

Parameters:
  • ignore_none – Properties which is None are excluded if True

  • ignore_empty – Properties which is empty are excluded if True

Returns:

Json string

Usage:

>>> from owlmixin.samples import Human
>>> human = Human.from_dict({
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple", "de": "Apfel"}},
...         {"name": "Orange"}
...     ]
... })
>>> print(human.to_pretty_json())
{
    "favorites": [
        {
            "name": "Apple",
            "names_by_lang": {
                "de": "Apfel",
                "en": "Apple"
            }
        },
        {
            "name": "Orange"
        }
    ],
    "id": 1,
    "name": "Tom"
}
to_yaml(*, ignore_none: bool = True, ignore_empty: bool = False) str

From instance to yaml string

Parameters:
  • ignore_none – Properties which is None are excluded if True

  • ignore_empty – Properties which is empty are excluded if True

Returns:

Yaml string

Usage:

>>> from owlmixin.samples import Human
>>> human = Human.from_dict({
...     "id": 1,
...     "name": "Tom",
...     "favorites": [
...         {"name": "Apple", "names_by_lang": {"en": "Apple", "de": "Apfel"}},
...         {"name": "Orange"}
...     ]
... })
>>> print(human.to_yaml())
favorites:
  - name: Apple
    names_by_lang:
      de: Apfel
      en: Apple
  - name: Orange
id: 1
name: Tom
to_yamlf(fpath: str, encoding: str = 'utf8', *, ignore_none: bool = True, ignore_empty: bool = False) str

From instance to yaml file

Parameters:
  • fpath – Yaml file path

  • encoding – Yaml file encoding

  • ignore_none – Properties which is None are excluded if True

  • ignore_empty – Properties which is empty are excluded if True

Returns:

Yaml file path