将字符串转换为嵌套字典

时间:2020-01-29 13:26:09

标签: python python-3.x string dictionary for-loop

我有一个字符串,我想将其转换为Python中的嵌套字典。

示例输入:

import copy
diff_str = "/pathConstraint/latency/latencyValue"
value = "low"
diff_arr = diff.split("/")
final_temp_dict = dict()
for elem in reversed(diff_arr):
    if len(final_temp_dict) == 0:
        final_temp_dict.setdefault(elem, value)
    else:
        temp_final_dict = copy.deepcopy(final_temp_dict)
        final_temp_dict.setdefault(elem, temp_final_dict)
    print (final_temp_dict)

运行此程序时,我遇到错误,但没有得到预期的输出。

所需的输出为嵌套字典:

{"pathConstraint" : {"latency" : {"latencyValue" : "low"}}}

5 个答案:

答案 0 :(得分:3)

您可以使用以下递归函数:

def string_to_dict(keys, value):
    key = keys.split('/')
    if len(key) == 2:
        return {key[1]: value}
    else:
        return string_to_dict('/'.join(key[:-1]), {key[-1]: value})

输出:

>>> string_to_dict(diff_str, value)
{'pathConstraint': {'latency': {'latencyValue': 'low'}}}

请注意,这假设diff_str/字符开头。

答案 1 :(得分:1)

更短的递归方法:

def to_dict(d, v):
  return v if not d else {d[0]:to_dict(d[1:], v)}


diff_str = "/pathConstraint/latency/latencyValue"
value = "low"
print(to_dict(list(filter(None, diff_str.split('/'))), value))

输出:

{'pathConstraint': {'latency': {'latencyValue': 'low'}}}

答案 2 :(得分:0)

以下是一种迭代方法。注意diff_arr[1:]用于排除在初始/上拆分产生的空字符串。

diff_str = "/pathConstraint/latency/latencyValue"
value = "low"
diff_arr = diff_str.split("/")
for key in list(reversed(diff_arr[1:])):
    value = {key: value}
print(value)

输出

{'pathConstraint': {'latency': {'latencyValue': 'low'}}}

答案 3 :(得分:0)

我试图尽可能少地修改您的功能,这应该可以正常工作

import copy
def func():
    diff_str = "/pathConstraint/latency/latencyValue"
    value = "low"
    diff_arr = diff_str.split("/")
    final_temp_dict = dict()
    for elem in reversed(diff_arr):
        if elem == "":
            continue
        if len(final_temp_dict) == 0:
           final_temp_dict[elem] = value
        else:
           temp_final_dict = copy.deepcopy(final_temp_dict)
           final_temp_dict = {}
           final_temp_dict[elem] = temp_final_dict

    print (final_temp_dict)

但是,有很多更好的方法可以执行这样的操作。请参阅其他答案以获取灵感。

答案 4 :(得分:0)

def convert(items, value):
    if not items:
        return value

    return {items.pop(0): convert(items, value)}


print(convert(diff_str.strip('/').split('/'), 'low'))