2013-03-13 50 views
5

问题是: 拥有一个名称列表和一个列表列表,如何创建一个列表,其中每个项目是一个有名字作为关键字的有序字典,以及列表作为值列表中的项目?这可能是从下面的代码更加清晰:如何从列表中制作有序的词典?

from collections import OrderedDict 

list_of_lists = [ 
       ['20010103', '0.9507', '0.9569', '0.9262', '0.9271'], 
       ['20010104', '0.9271', '0.9515', '0.9269', '0.9507'], 
       ['20010105', '0.9507', '0.9591', '0.9464', '0.9575'], 
       ] 

names = ['date', 'open', 'high', 'low', 'close'] 

我想获得:

ordered_dictionary = [ 
        OrderedDict([('date', '20010103'), ('open', '0.9507'), ('high', '0.9569'), ('low', '0.9262'), ('close', '0.9271')]), 
        OrderedDict([('date', '20010104'), ('open', '0.9271'), ('high', '0.9515'), ('low', '0.9269'), ('close', '0.9507')]), 
        OrderedDict([('date', '20010105'), ('open', '0.9507'), ('high', '0.9591'), ('low', '0.9464'), ('close', '0.9575')]), 
        ] 

回答

10

使用zip()的名称和值组合。与列表理解:

from collections import OrderedDict 

ordered_dictionary = [OrderedDict(zip(names, subl)) for subl in list_of_lists] 

这给:

>>> from pprint import pprint 
>>> pprint([OrderedDict(zip(names, subl)) for subl in list_of_lists]) 
[OrderedDict([('date', '20010103'), ('open', '0.9507'), ('high', '0.9569'), ('low', '0.9262'), ('close', '0.9271')]), 
OrderedDict([('date', '20010104'), ('open', '0.9271'), ('high', '0.9515'), ('low', '0.9269'), ('close', '0.9507')]), 
OrderedDict([('date', '20010105'), ('open', '0.9507'), ('high', '0.9591'), ('low', '0.9464'), ('close', '0.9575')])] 
+0

谢谢!清晰优雅的解决方案! – atman 2013-03-13 10:43:25

0

我知道这个问题是很老了,但我想我会提出一个解决方案namedtuple作为替代OrderedDict,将在正常工作这种情况:

from collections import namedtuple 

Bar = namedtuple('Bar', ['date', 'open', 'high', 'low', 'close']) 

bars = [Bar(date, o, h, l, c) for date, o, h, l, c in list_of_lists] 

>>> bars 
[Bar(date='20010103', open='0.9507', high='0.9569', low='0.9262', close='0.9271'), 
Bar(date='20010104', open='0.9271', high='0.9515', low='0.9269', close='0.9507'), 
Bar(date='20010105', open='0.9507', high='0.9591', low='0.9464', close='0.9575')] 

>>> bars[2].date 
'20010105' 

>>> bars[2].close 
'0.9575' 

更妙的是,可以使用字典解析与日期为重点:

Bar = namedtuple('Bar', ['open', 'high', 'low', 'close']) 

bars = {date: Bar(o, h, l, c) for date, o, h, l, c in list_of_lists} 

>>> bars 
{'20010103': Bar(open='0.9507', high='0.9569', low='0.9262', close='0.9271'), 
'20010104': Bar(open='0.9271', high='0.9515', low='0.9269', close='0.9507'), 
'20010105': Bar(open='0.9507', high='0.9591', low='0.9464', close='0.9575')} 

>>> bars['20010105'] 
Bar(open='0.9507', high='0.9591', low='0.9464', close='0.9575') 

>>> bars['20010105'].close 
'0.9575'