2017-05-05 100 views
1

我有一個包含1個鍵和多個列表值的字典。將列表字典中的每個值(列表)寫入新行

{'A-03131': [['Component', 'P-011510', '5'], ['Component', 'P-011319', '1'], ['Component', 'A-03134', '1'], ['Component', 'P-009591', '1'], ['Component', 'P-011509', '1'], ['Component', 'P-011461', '1'], ['Component', 'P-011563', '1'], ['Component', 'A-03094', '2'], ['Component', 'A-03146', '1'], ['Component', 'P-011465', '4']]} 

我想寫每個列表值到CSV自己的行。 我目前已經得到這個:

with open(file, 'w+') as outfile : 
     w = csv.writer(outfile) 
     w.writerows(sub_assembly.items()) 

但是,這是寫完整的字典一行。

回答

0

我發現dict.values()適合我的需求。

filename = parent_item + '_bom.csv' 
file = os.path.join(OUTPATH, filename) 
header_row = ['Parent Item ', parent_item] 
with open(file, 'w+') as outfile: 
    w = csv.writer(outfile, delimiter=',') 
    w.writerow(header_row) 
    for value in main_bom.values(): 
     w.writerows(value) 
1

基本上在處理excel文件時,使用openpyxl包。 而不是直接寫入遍歷所有行並將每個列表插入到一行中。

使用openpyxl,

wb = openpyxl.Worksheet()

ws = wb.active

for value in d['A-03131']: cell(row = row,column = column).value = value

wb.save('assembly.xlsx')

這是做Excel的操作更優雅的方式。

+0

我需要我的輸出爲csv格式以便進一步處理。我想我已經找到了我的解決方案,一旦我得到它的工作 – AlliDeacon

+0

我想你已經得到了答案。 – bigbounty

相關問題