将列表字典中的每个值(列表)写入新行
问题描述:
我有一个包含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())
但是,这是写完整的字典一行。
答
我发现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)
答
基本上在处理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的操作更优雅的方式。
我需要我的输出为csv格式以便进一步处理。我想我已经找到了我的解决方案,一旦我得到它的工作 – AlliDeacon
我想你已经得到了答案。 – bigbounty