Commit c7893edf authored by Gregory Ashton's avatar Gregory Ashton
Browse files

Fix bug in which the cached data check always failed

Makes the decoding less aggressive. This was causing various things to
be coerced into a list when they where dictionaries etc.
parent e5fc75be
Pipeline #20609 passed with stages
in 15 minutes and 1 second
......@@ -39,7 +39,8 @@ class Result(dict):
def __init__(self, dictionary=None):
if type(dictionary) is dict:
for key in dictionary:
setattr(self, key, self._decode_object(dictionary[key], key))
val = self._standardise_strings(dictionary[key], key)
setattr(self, key, val)
def __getattr__(self, name):
......@@ -62,21 +63,17 @@ class Result(dict):
return ''
def _decode_object(self, item, name=None):
""" When reading in data, ensure all bytes are decoded to strings """
if type(item) == pd.DataFrame:
return item
def _standardise_a_string(self, item):
""" When reading in data, ensure all strings are decoded correctly """
if type(item) in [bytes]:
return item.decode()
except AttributeError:
return [i.decode() for i in item]
except (AttributeError, TypeError):
return item
logging.debug("Unable to decode item {}".format(name))
def _standardise_strings(self, item, name=None):
if type(item) in [list]:
item = [self._standardise_a_string(i) for i in item]
#logging.debug("Unable to decode item {}".format(name))
return item
def get_result_dictionary(self):
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment