2013-08-01 31 views
5

如何迭代字典中的一系列键?如何遍历字典中的一系列键?

举例来说,如果我有以下的解释:

{'Domain Source': 'Analyst', 'Recommend Suppress': 'N', 'Standard Error': '0.25', 'Element ID': '1.A.1.d.1', 'N': '8', 'Scale ID': 'IM', 'Not Relevant': 'n/a', 'Element Name': 'Memorization', 'Lower CI Bound': '2.26', 'Date': '06/2006', 'Data Value': '2.75', 'Upper CI Bound': '3.24', 'O*NET-SOC Code': '11-1011.00'} 

我怎么会遍历唯一标准错误后的钥匙?理想情况下,我希望得到所有符合标准错误的值。

谢谢!


只是为了报告的评价:我知道iteritems(),但是当我试图下标,返回了一个错误:未标化。此外,键/值每次都以相同的顺序出现。

+0

您可以使用iterkeys()方法迭代键。例如:[键为mydict.iterkeys()中的键)。 –

+1

@HugoCorrá这只是在字典中的键是有用的存储在他们插入的顺序,因此看到答案jterrace – hetepeperfan

+0

对不起,我误解了。现在我明白有序v。无序字典的重要性。 – goldisfine

回答

6

Python字典中的键没有任何特定的顺序。

您需要改为使用OrderedDict

例如:

>>> d = OrderedDict([('key1', 'value1'), ('key2', 'value2'), ('key3', 'value3')]) 

现在的关键是保证,以便返回:

>>> d.keys() 
['key1', 'key2', 'key3'] 

如果你想有一个特定的值之后,抓住所有的键,你可以使用itertools.dropwhile

>>> import itertools 
>>> list(itertools.dropwhile(lambda k: k != 'key2', d.iterkeys())) 
['key2', 'key3'] 
2

这里的问题是Python字典是无序的,因此在'Standard Error'之后遍历密钥没有意义。

2

问题是,词典是无序的。一旦你做到了,你就无法依赖项目的顺序。所以,如果你想一般的解决方案,你可以使用OrderedDict

如果你已经在词典数据,您可以明确地排除两个第一项:

>>> d = {'Domain Source': 'Analyst', 'Recommend Suppress': 'N', 'Standard Error': '0.25', 'Element ID': '1.A.1.d.1', 'N': '8', 'Scale ID': 'IM', 'Not Relevant': 'n/a', 'Element Name': 'Memorization', 'Lower CI Bound': '2.26', 'Date': '06/2006', 'Data Value': '2.75', 'Upper CI Bound': '3.24', 'O*NET-SOC Code': '11-1011.00'} 
>>> [x for x in d if x not in ('Domain Source', 'Recommend Suppress')] 
['N', 'Scale ID', 'Not Relevant', 'Element Name', 'Data Value', 'Standard Error', 'Element ID', 'Lower CI Bound', 'Date', 'Upper CI Bound', 'O*NET-SOC Code'] 
+0

需要iteritems()? – goldisfine

2

字典不存储键/值按照您添加它们的顺序进行配对...除非使用OrderedDict。方法如下:

entries = [('Domain Source', 'Analyst'), ('Recommend Suppress', 'N'), 
('Standard Error', '0.25'), ('Element ID', '1.A.1.d.1'), 
('N', '8'), ('Scale ID', 'IM'), ('Not Relevant', 'n/a'), 
('Element Name', 'Memorization'), ('Lower CI Bound', '2.26'), 
('Date', '06/2006'), ('Data Value', '2.75'), 
('Upper CI Bound', '3.24'), ('O*NET-SOC Code', '11-1011.00')] 

from collections import OrderedDict 
d = OrderedDict(entries) 
d.keys()[2:] 

=> ['Standard Error', 'Element ID', 'N', 'Scale ID', 'Not Relevant', 
    'Element Name', 'Lower CI Bound', 'Date', 'Data Value', 
    'Upper CI Bound', 'O*NET-SOC Code']