需要将有序词典的有序词典转换为词典词典

时间:2018-08-22 12:13:05

标签: python dictionary recursion ordereddictionary

我有一个数据集,其中可能有n个有序字典的有序字典,现在我需要将它们全部转换为普通字典,除了递归搜索和转换之外,还有没有其他更简单的方法了?

from collections import OrderedDict
an=OrderedDict([('method', 'constant'), ('data', '1.225')])

aw=OrderedDict([('method', 'constant'), ('data', OrderedDict([('1.225','777')]))])

print dict(an)
print dict(aw)
{'data': '1.225', 'method': 'constant'}
{'data': OrderedDict([('1.225', '777')]), 'method': 'constant'}

1 个答案:

答案 0 :(得分:2)

可能不是。您可以将递归算法包装在一个函数中:

from collections import OrderedDict

def ordered_to_regular_dict(d):
    if isinstance(d, OrderedDict):
        d = {k: ordered_to_regular_dict(v) for k, v in d.items()}
    return d

aw = OrderedDict([('method', 'constant'), ('data', OrderedDict([('1.225','777')]))])
res = ordered_to_regular_dict(aw)

# {'data': {'1.225': '777'}, 'method': 'constant'}