我有一个数据集,其中可能有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'}发布于 2018-08-22 20:17:30
可能不会。您可以将递归算法封装在一个函数中:
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'}https://stackoverflow.com/questions/51966629
复制相似问题