0

我以为我发现通过清除字典来对字典进行排序,然后按照我想要的顺序重新组装它,但由于某种原因,它会按照开始的方式重新排序。

如果有人可以帮助我,这是代码

from operator import itemgetter

n = {}
d = {
 'a': ['2', 'ova', 'no'], 
 'b': ['23', 'movie', 'yes'], 
 'c': ['5', 'show', 'yes'], 
 'd': ['17', 'ova', 'yes'], 
 'e': ['1', 'movie', 'no']
}

for i in d:
    print i, d[i]

print '\n'

l = d.items()
l.sort(key=itemgetter(1)) #l is now sorted by the value of the string holding the integers
d.clear()

for i in l:
    print i[0], i[1]
    d[i[0]] = i[1] 

print '\n'

for i in d:
    print i, d[i] #Why does the dictionary come out to be the same it started from
4

2 回答 2

10

字典本质上是无序的(因为它们使用哈希键 - 这是唯一但任意的)[这是一个常见问题解答] - 您可能需要考虑使用保留插入顺序的OrderedDict (在 2.7+ 中)或来自 PyPi 的配方 - 否则,如果您需要顺序,则需要将条目保存在列表或其他顺序中。

于 2012-07-11T00:40:20.000 回答
4

正如乔恩所指出的,字典没有顺序。通过放弃订购,您可以获得快速查找。不过,您可能不需要它来保持订单,因为您有自己喜欢的排序顺序:

d = {'a':['2', 'ova', 'no'], 'b':['23', 'movie', 'yes'], 'c':['5', 'show', 'yes'], 'd':['17', 'ova', 'yes'], 'e':['1', 'movie', 'no']}
sorted_items = sorted(d.items(), key=itemgetter(1))
for i,v in sorted_items:
    print i, v
于 2012-07-11T00:51:02.143 回答