从python中的n个csv文件创建excel文件

时间:2017-12-16 07:53:18

标签: python excel csv

我试图将csv文件中的数据放入python 2.7 windows 7中的excel文件中。 每次我使用以下函数时,python都会将csv转换为相应的文件并命名它,但这是问题所在。我希望将一个csv文件的数据复制到它的相应excel文件和第二个excel文件中的第二个csv的数据但是我犯的错误是在创建第一个excel之后,第一个excel的数据被复制到第二个excel文件。所以第二个excel除了它自己的csv文件数据外,还有来自1st excel的数据。而第3个excel拥有1st excel + 2nd excel和3rd excel的数据。 谁能告诉我我做错了什么? 附件是代码:

import xlwt
import os
path = ('C:\Users\PETERemote\PycharmProjects\untitled\distributions')
data = []
count =1
count2 = 0
for files in os.listdir(path):
    if files.endswith("COUNT16_DISTRIBUTION" + str(count*1) + ".csv"):
        count += 1
count2 = count-1
print(count2)
#print(count2 = count)

count3=1
file_name = "COUNT16_DISTRIBUTION" + str(count3*1) + ".csv"
while (count3<=count2):
    with open(file_name) as f:
        for line in f:
            data.insert([word for word in line.split("  ") if word])
    wb = xlwt.Workbook()
    output_file = open("COUNT16_DIST" + str(count3 * 1) + ".xls", 'w')
    count3 += 1
    sheet = wb.add_sheet("Sheet1")
    for row_index in range(len(data)):
        for col_index in range(len(data[row_index])):
            sheet.write(row_index, col_index, data[row_index][col_index])
    wb.save(output_file)
    output_file.close()

1 个答案:

答案 0 :(得分:1)

您只需向data添加内容。

这就是为什么到目前为止每个输出文件都包含所有输入文件的内容。

保存输出文件后应立即清除数据:

wb.save(output_file)
data = []