Improved code quality.
This commit is contained in:
parent
4199b9d605
commit
d239e04324
|
@ -9,46 +9,33 @@ def _get_index(key):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
def _get_item_value(item, key):
|
def _get_item_key_and_value(item, key):
|
||||||
if type_util.is_list(item):
|
if type_util.is_list(item):
|
||||||
index = _get_index(key)
|
index = _get_index(key)
|
||||||
if index is not None:
|
if index is not None:
|
||||||
return item[index]
|
return (index, item[index], )
|
||||||
elif type_util.is_dict(item):
|
elif type_util.is_dict(item):
|
||||||
return item[key]
|
return (key, item[key], )
|
||||||
raise KeyError
|
raise KeyError
|
||||||
|
|
||||||
|
|
||||||
|
def _get_or_new_item_value(item, key, subkey):
|
||||||
|
try:
|
||||||
|
item_key, item_value = _get_item_key_and_value(item, key)
|
||||||
|
if not type_util.is_dict_or_list(item_value):
|
||||||
|
raise TypeError
|
||||||
|
except (IndexError, KeyError, TypeError, ):
|
||||||
|
item_value = _new_item_value(subkey)
|
||||||
|
item[key] = item_value
|
||||||
|
return item_value
|
||||||
|
|
||||||
|
|
||||||
def _new_item_value(key):
|
def _new_item_value(key):
|
||||||
index = _get_index(key)
|
index = _get_index(key)
|
||||||
return {} if index is None else []
|
return {} if index is None else []
|
||||||
|
|
||||||
|
|
||||||
def get_item(d, keys):
|
def _set_item_value(item, key, value):
|
||||||
items = get_items(d, keys)
|
|
||||||
return items[-1] if items else (None, None, None, )
|
|
||||||
|
|
||||||
|
|
||||||
def get_items(d, keys):
|
|
||||||
items = []
|
|
||||||
item = d
|
|
||||||
value = None
|
|
||||||
for key in keys:
|
|
||||||
try:
|
|
||||||
value = _get_item_value(item, key)
|
|
||||||
if type_util.is_list(item):
|
|
||||||
index = _get_index(key)
|
|
||||||
items.append((item, index, value, ))
|
|
||||||
else:
|
|
||||||
items.append((item, key, value, ))
|
|
||||||
item = value
|
|
||||||
except (IndexError, KeyError, ):
|
|
||||||
items.append((None, None, None, ))
|
|
||||||
break
|
|
||||||
return items
|
|
||||||
|
|
||||||
|
|
||||||
def set_item_value(item, key, value):
|
|
||||||
index = _get_index(key)
|
index = _get_index(key)
|
||||||
if index is not None:
|
if index is not None:
|
||||||
try:
|
try:
|
||||||
|
@ -62,6 +49,26 @@ def set_item_value(item, key, value):
|
||||||
item[key] = value
|
item[key] = value
|
||||||
|
|
||||||
|
|
||||||
|
def get_item(d, keys):
|
||||||
|
items = get_items(d, keys)
|
||||||
|
return items[-1] if items else (None, None, None, )
|
||||||
|
|
||||||
|
|
||||||
|
def get_items(d, keys):
|
||||||
|
items = []
|
||||||
|
item = d
|
||||||
|
value = None
|
||||||
|
for key in keys:
|
||||||
|
try:
|
||||||
|
item_key, item_value = _get_item_key_and_value(item, key)
|
||||||
|
items.append((item, item_key, item_value, ))
|
||||||
|
item = item_value
|
||||||
|
except (IndexError, KeyError, ):
|
||||||
|
items.append((None, None, None, ))
|
||||||
|
break
|
||||||
|
return items
|
||||||
|
|
||||||
|
|
||||||
def set_item(d, keys, value):
|
def set_item(d, keys, value):
|
||||||
item = d
|
item = d
|
||||||
i = 0
|
i = 0
|
||||||
|
@ -69,16 +76,8 @@ def set_item(d, keys, value):
|
||||||
while i < j:
|
while i < j:
|
||||||
key = keys[i]
|
key = keys[i]
|
||||||
if i < (j - 1):
|
if i < (j - 1):
|
||||||
try:
|
item = _get_or_new_item_value(item, key, keys[i + 1])
|
||||||
subitem = _get_item_value(item, key)
|
|
||||||
if not type_util.is_dict_or_list(subitem):
|
|
||||||
raise TypeError
|
|
||||||
except (IndexError, KeyError, TypeError, ):
|
|
||||||
subkey = keys[i + 1]
|
|
||||||
subitem = item[key] = _new_item_value(subkey)
|
|
||||||
item = subitem
|
|
||||||
i += 1
|
i += 1
|
||||||
continue
|
continue
|
||||||
set_item_value(item, key, value)
|
_set_item_value(item, key, value)
|
||||||
break
|
break
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue