python – 递归地按键对嵌套的OrderedDict进行排序
发布时间:2020-11-18 09:33:35 所属栏目:Python 来源:互联网
导读:假设orig是一个包含普通字符串:字符串键值对的OrderedDict,但有时该值可能是另一个嵌套的OrderedDict. 我想按键,按字母顺序(升序)对orig进行排序,并以递归方式进行. 规则: 假设键字符串是不可预测的 假设嵌套可以无限发生,例如级别1-50都具有字符串,Ordered
|
假设orig是一个包含普通字符串:字符串键值对的OrderedDict,但有时该值可能是另一个嵌套的OrderedDict. 我想按键,按字母顺序(升序)对orig进行排序,并以递归方式进行. 规则: >假设键字符串是不可预测的 需要协助排序算法: import string
from random import choice
orig = OrderedDict((
('a',choice(string.digits)),('b',('c',('special',OrderedDict((
('a',)))
))
sorted_copy = OrderedDict(sorted(orig.iteritems(),...))
self.assertEqual(orig,sorted_copy)
解决方法编辑:对于python 3.6,@ pelson的答案更好就像是: def sortOD(od):
res = OrderedDict()
for k,v in sorted(od.items()):
if isinstance(v,dict):
res[k] = sortOD(v)
else:
res[k] = v
return res (编辑:日照站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- Python – 具有有限十进制数字的随机浮点数
- python 面向对象类与类之间的关系
- python – Numpy相当于if / else list comprehension
- python – Sklearn中使用GridSearchCV的OneVsRestClassific
- 在Django-South中,Pesky“Table’my_table’已经存在”
- Python __init__.py和类
- 从python执行Shell脚本与变量
- Django休息框架:query_route中的查询参数
- 如何使用Python读取大文件
- 使用Python在OpenOffice / Microsoft Word中格式化输出
