2014-01-15 3 views
0

이것은 지금까지 가지고있는 코드입니다.사전 값이 목록 인 csv에 사전 목록을 작성하십시오.

list_of_dict = [{'A': [1, 2, 3, 4, 5], 'B': [10, 11]}] 
with open('result.csv','wb') as out: 
    f1 = csv.DictWriter(out,list_of_dict[0].keys()) 
    f1.writeheader() 
    f1.writerows(list_of_dict) 

출력은 다음과 같습니다.

 A   B 
[1,2,3,4,5] [10,11] 

어떻게 출력을 얻을 수 있습니까?

A B 
1 10 
2 11 
3 
4 
5 

답변

1
당신은 사전의 목록을 출력의 각 행에 대해 하나로 한 사전을 바꾸어해야합니다

: 키가 사전에 나열되어가는 것을

import csv 
from itertools import izip_longest 

with open('result.csv','wb') as out: 
    keys = list_of_dict[0].keys() 
    f1 = csv.DictWriter(out, keys) 
    f1.writeheader() 
    f1.writerows(dict(zip(keys, row)) for row in izip_longest(*list_of_dict[0].values())) 

주 (임의) 주문.

>>> from itertools import izip_longest 
>>> list_of_dict = [{'A': [1, 2, 3, 4, 5], 'B': [10, 11]}] 
>>> keys = list_of_dict[0].keys() 
>>> [dict(zip(keys, row)) for row in izip_longest(*list_of_dict[0].values())] 
[{'A': 1, 'B': 10}, {'A': 2, 'B': 11}, {'A': 3, 'B': None}, {'A': 4, 'B': None}, {'A': 5, 'B': None}] 
: 상기 발전기의 발현에 필요한 사전 당 행을 생성