将列表字典中的每个值(列表)写入新行

时间:2017-05-05 12:10:04

标签: csv dictionary python-3.5

我有一个包含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())

但那就是把完整的字典写成一行。

2 个答案:

答案 0 :(得分: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操作的更优雅方式。

答案 1 :(得分: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)