util module
metaparser utility class
Purpose of this class is helping user manipulating the parser output data structures (e.g.: nested dictionaries)
- genie.metaparser.util.keynames_exist(dic, key_list)
Method to validate if all the keys provided from key_list existing in given dict
- Parameters
dic (
dict
) – the given dictionarykey_list (
list
) – list of keys (nestedkeys) need to be checked against dic.
Example
>>> dic = {'d': 1, 'e': {'f': 2, 'ff': 3}} >>> keynames_exist(dic, ['d', 'e.f']) OR >>> keynames_exist(dic, [['d'], ['e','f']]) OR >>> keynames_exist(dic, [('d',), ('e','f')])
- Returns
None - validation passed, all keys provided in key_list exist in dic exception - validation failed, one or more keys not in given dic
- genie.metaparser.util.dict_2_list_of_keys(dic, lst=None, loc=None)
Method returns a list of flattened dictionary keys (including all nested keys)
- Parameters
dic (
dict
) – the dictionary used to generate keys
Examples
>>> dic = {'k1': 'v1', 'k2': {'k21': 'v21', 'k22': 'v22'}} >>> dict_2_list_of_keys(dic)
Returns: [[‘k1’], [‘k2’, ‘k21’], [‘k2’, ‘k22’]]
- genie.metaparser.util.keynames_convert(dic, mapping)
Method to to convert a list of nested key names
- Parameters
dic (
dict
) – original dictionary needs to be convertedmapping (
list of tuples
) – list of tuples defines the key mapping relationship. for example: [(‘k2.k21’,’k21_new’), (‘k1’,’k1_new’), (‘k2.k22’,’k22_new’)] Also support list of list format: [[‘k2.k21’,’k21_new’], [‘k1’,’k1_new’], [‘k2.k22’,’k22_new’]]
Example
>>> dic = {'k1': 'v1', 'k2': {'k21': 'v21', 'k22': 'v22'}} >>> mapping = [('k2.k21','k21_new'), ('k1','k1_new'), ... ('k2.k22','k22_new')] >>> keynames_convert(dic, mapping)
Returns: {‘k1_new’: ‘v1’, ‘k2’: {‘k21_new’: ‘v21’, ‘k22_new’: ‘v22’}}
- genie.metaparser.util.nestedkey_rename(dic, keymap, new_key)
Method to rename a single key name of a nested dictionary
- Parameters
dic (
dict
) – dictionary needs to be key renamedkeymap – (
list
ortuple
): list (tuple) of nested keysnew_key ('str') – new key name
Example
>>> dic = {'k1': 'v1', 'k2': {'k21': 'v21', 'k22': 'v22'}} >>> nested_rename(dic, ['k2', 'k21'], 'k21_new') OR >>> nested_rename(dic, ('k2', 'k21'), 'k21_new')
Returns: {‘k1’: ‘v1’, ‘k2’: {‘k21_new’: ‘v21’, ‘k22’: ‘v22’}}
- genie.metaparser.util.reform_nestdict_from_keys(dic, key_list)
Method returns a new nested dictionary from a given dictionary with specific keysdefined in key_list
- Parameters
dic (
dict
) – the template dictionary used to generate new dictkey_list ('list') – a list of nested keys from the template dict. format support: [[‘a’, ‘b’, ‘c’], [‘a’, ‘b’, ‘d’]] OR [‘a.b.c’, ‘a.b.d’]
Examples
>>> dic = {'k1': 'v1', 'k2': {'k21': 'v21', 'k22': 'v22'}} >>> reform_nestdict_from_keys(dic, ['k1', 'k2.k21'])
Returns: {‘k1’: ‘v1’, ‘k2’: {‘k21’: ‘v21’}}
- genie.metaparser.util.create_dict_from_nestedkeys(keymap, value)
Method returns a new nested dictionary with one nested key and value
- Parameters
keymap (
list
) – a list contains flattened nested keysvalue ('obj') – the value for this nested key
Examples
>>> create_dict_from_nestedkeys(['a','b','c'], 22)
Returns: {‘a’ {‘b’: {‘c’: 22}}}
- genie.metaparser.util.get_value_from_nestdict(dic, keymap)
method gets a value from a nested key in a nested dict
- Parameters
dic ('dict') – a nested dict
keymap (
list
) – a list contains flattened nested keys
Examples
>>> get_value_from_nestdict({'a' {'b': {'c': 22, 'd': 33}}}, ... ['a','b','c'])
Returns: 22
- genie.metaparser.util.merge_dict(dic_result, dic, path=None, update=False, ignore_update=False)
Method merges dic into dic_result
- Parameters
dic_result – the dict will be returned
dic ('dict') – the dict used to merge with dict_result
path (
list
) – internal variable for keeping track of stackupdate (
bool
) – dic will update dic_result in case of key value mismatchignore_update (
bool
) – dic won’t update dic_result in case of key value mismatch
Examples
>>> merge_dict({'province': {'city': 'ottawa'}}, ... {'province': {'county': 'kanata'}})
Returns: {‘province’: {‘county’: ‘kanata’, ‘city’: ‘ottawa’}}