如何排序字典?

时间:2012-05-16 16:19:35

标签: python dictionary

问题是房间号码和客人详细信息的列表我直接从一个txt文件中删除,该文件需要放入字典中,房间号作为键,细节作为值。

客人名单实际上是一个列表,每个项目代表房间号,客人姓名,到达,出发日期。没有任何东西的房间都是空的。

nlist = [['101'], ['102'], ['103'], 
['201', ' John Cleese', ' 5/5/12', ' 5/7/12'], ['202'], 
['203', ' Eric Idle', ' 7/5/12', ' 8/7/12'], ['301'], ['302'], ['303']]

基本上,要把它变成字典。这是我试过的:

guests = {}
for i in nlist:
        if len(i) == 1:
            key = i[0]
            guests[key] = None
        else:
            key = i[0]
            val = i[1],i[2],i[3]
            guests[key] = val

给了我:

guests = {'201': (' John Cleese', ' 5/5/12', ' 5/7/12'), 
'203': (' Eric Idle', ' 7/5/12', ' 8/7/12'), '202': None, '301': None, 
'302': None, '303': None, '102': None, '103': None, '101': None}

正如您所看到的,字典按特定顺序排列在一起。但是对于这个特定的练习,词典需要从最低到最高的房间号。我想我认为它会从头到尾遍历每个内部列表,测试它,然后按顺序构建字典。

有没有人知道如何正确编写代码,以便字典出现为{'101':无,'102',无,'103':无......等等)?希望有人可以解释为什么我的代码不能像我预期的那样工作。

1 个答案:

答案 0 :(得分:10)

标准Python字典本质上是无序的。

一种可能性是使用OrderedDict。它将保留插入顺序,这意味着您必须按照您希望检索它们的顺序插入条目。

另一种可能性是保持dict不变,但按所需顺序迭代:

for k, v in sorted(guests.items()):
  print k, v

最后,应该注意的是,您的示例将房间号码存储为字符串而不是整数。这意味着排序是词典('90' > '100')。由于这是作业,我把它留作阅读练习,以弄清楚如何解决这个问题。