繁体   English   中英

将字符串转换为嵌套字典

[英]Converting a string to a nested dictionary

我有一个字符串,我想将其转换为 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"}}}

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

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/字符开头。

更短的递归方法:

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'}}}

以下是迭代方法。 注意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'}}}

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

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)

然而,有很多更好的方法来做这样的事情。 请参阅其他答案以获取灵感。

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

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


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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM