diff options
author | Runar Borge <runar@borge.nu> | 2018-06-09 22:31:09 +0200 |
---|---|---|
committer | Runar Borge <runar@borge.nu> | 2018-06-09 22:31:09 +0200 |
commit | f3b4cfecbe48c75c88b9396f68c4b9fc2d7babc1 (patch) | |
tree | a043804da4a0b841c86455ceb8c9e8d5f73f7717 /python/vyos/util.py | |
parent | 06b807f9b898c6bef55c9c0888bf5fd1c96bc9bd (diff) | |
parent | e916c9a55ffdff970c1796829d1bee319802b353 (diff) | |
download | vyos-1x-f3b4cfecbe48c75c88b9396f68c4b9fc2d7babc1.tar.gz vyos-1x-f3b4cfecbe48c75c88b9396f68c4b9fc2d7babc1.zip |
Merge branch 'current' of git://github.com/vyos/vyos-1x into current
Diffstat (limited to 'python/vyos/util.py')
-rw-r--r-- | python/vyos/util.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/python/vyos/util.py b/python/vyos/util.py new file mode 100644 index 000000000..9a36ef84f --- /dev/null +++ b/python/vyos/util.py @@ -0,0 +1,50 @@ +import re + + +def colon_separated_to_dict(data_string, uniquekeys=False): + """ Converts a string containing newline-separated entries + of colon-separated key-value pairs into a dict. + + Such files are common in Linux /proc filesystem + + Args: + data_string (str): data string + uniquekeys (bool): whether to insist that keys are unique or not + + Returns: dict + + Raises: + ValueError: if uniquekeys=True and the data string has + duplicate keys. + + Note: + If uniquekeys=True, then dict entries are always strings, + otherwise they are always lists of strings. + """ + key_value_re = re.compile('([^:]+)\s*\:\s*(.*)') + + data_raw = re.split('\n', data_string) + + data = {} + + for l in data_raw: + l = l.strip() + if l: + match = re.match(key_value_re, l) + if match: + key = match.groups()[0].strip() + value = match.groups()[1].strip() + if key in data.keys(): + if uniquekeys: + raise ValueError("Data string has duplicate keys: {0}".format(key)) + else: + data[key].append(value) + else: + if uniquekeys: + data[key] = value + else: + data[key] = [value] + else: + pass + + return data |