我是Python的初学者。 不知道如何在字典中设置顺序? . 我搜索并知道它可以通过from collections import OrderedDict
完成,但不知道如何使用它。 我正在尝试在下面提及代码来比较两个字典,但我没有得到按顺序输出.
d = { k[0]: k[1:] for k in a }
d2= { k[0]: k[1:] for k in b }
p = {i:j for i,j in d2.items() if i not in d}
q = {i:j for i,j in d.items() if i not in d2}
知道如何做到这一点吗?
更新的问题 :
i have a nested list . How to get each list of nested list in next line ?
[['Eth116/1/12 sales connected 1 full 10G Fabric Exte'], ['Eth116/1/13 marketing connected 190 full 100 ']]
预期输出 :
Eth116/1/12 sales connected 1 full 10G Fabric Exte
Eth116/1/13 marketing connected 190 full 100
字典是无序的,除了编写自己的dict
子类(不推荐(之外,您无能为力。如 hiro 主角的评论所示,使用OrderedDict
就可以了,只要您记住OrderedDict
中的顺序是插入顺序,与键的值无关。(Python 3dict
s的排序也是如此。如果a
和b
具有相同的元素,但顺序不同,则生成的OrderedDict
将不相等,除非您事先对a
和b
进行排序。
如果要比较无法轻松确定插入顺序的两个dict
,则需要支持无序比较的数据结构。我没有你的数据,所以我不得不弥补一些。我从这个输入开始
>>> a
[[1, 3, 5, 7, 9], [4, 9, 14, 19, 24, 29, 34, 39], [8, 17, 26, 35, 44, 53, 62, 71], [9, 19, 29, 39, 49, 59, 69, 79, 89]]
>>> b
[[1, 3, 5, 7, 9], [4, 9, 14, 19, 24, 29, 34, 39], [8, 17, 26, 35, 44, 53, 62, 71]]
如您所见,a
有一个额外的元素以9
开头
。修改字典构造代码以使值元组不列出,因为字典值需要可哈希才能在下一步中起作用:
>>> d = { k[0]: tuple(k[1:]) for k in a }
>>> d2= { k[0]: tuple(k[1:]) for k in b }
然后,您可以将字典转换为集合以执行无序比较:
>>> s = set(d.items())
>>> s2 = set(d2.items())
>>> s == s2
False
您可以使用集合运算符来发现区别是什么:
>>> s2 <= s
True
>>> s - s2
set([(9, (19, 29, 39, 49, 59, 69, 79, 89))])
从 python 3.6 开始,字典在 python 中排序,对于超过该数字的 python,请忽略上面的答案!
看这里,在堆栈溢出