5

问题是我直接从一个 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': None, '102', None, '103': None... etc.)?希望有人能解释为什么我的代码也没有按我的预期工作。

4

1 回答 1

10

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

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

另一种可能性是保持dict原样,但以所需的顺序迭代:

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

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

于 2012-05-16T16:21:27.317 回答