将Python列表写入csv中的列

时间:2013-07-17 15:40:11

标签: python list csv

我有5个列表,长度相同,我想将它们写入CSV中的5列。到目前为止,我只能使用以下代码写一个列:

with open('test.csv', 'wb') as f:
    writer = csv.writer(f)
    for val in test_list:
        writer.writerow([val])

如果我添加另一个for循环,它只会将该列表写入同一列。有人知道获得五个不同列的好方法吗?

7 个答案:

答案 0 :(得分:35)

将它们更改为行

rows = zip(list1,list2,list3,list4,list5)

然后只是

import csv

with open(newfilePath, "w") as f:
    writer = csv.writer(f)
    for row in rows:
        writer.writerow(row)

答案 1 :(得分:10)

以下代码将python列表写入csv

中的列
import csv
from itertools import zip_longest
list1 = ['a', 'b', 'c', 'd', 'e']
list2 = ['f', 'g', 'i', 'j']
d = [list1, list2]
export_data = zip_longest(*d, fillvalue = '')
with open('numbers.csv', 'w', encoding="ISO-8859-1", newline='') as myfile:
      wr = csv.writer(myfile)
      wr.writerow(("List1", "List2"))
      wr.writerows(export_data)
myfile.close()

输出看起来像这样

enter image description here

答案 2 :(得分:4)

您可以使用izip组合您的列表,然后迭代它们

for val in itertools.izip(l1,l2,l3,l4,l5):
    writer.writerow(val)

答案 3 :(得分:1)

我只是想添加一个内容-坦率地说,我撞了一下头-虽然对python很陌生-也许它将帮助其他人。

 writer.writerow(("ColName1", "ColName2", "ColName"))
                 for i in range(len(first_col_list)):
                     writer.writerow((first_col_list[i], second_col_list[i], third_col_list[i]))

答案 4 :(得分:0)

import csv
dic = {firstcol,secondcol} #dictionary
csv = open('result.csv', "w") 
for key in dic.keys():
    row ="\n"+ str(key) + "," + str(dic[key]) 
    csv.write(row)

答案 5 :(得分:0)

如果您很乐意使用第三方库,则可以使用Pandas。好处包括无缝访问专用方法和行/列标签:

import pandas as pd

list1 = [1, 2, 3]
list2 = [4, 5, 6]
list3 = [7, 8, 9]

df = pd.DataFrame(list(zip(*[list1, list2, list3]))).add_prefix('Col')

df.to_csv('file.csv', index=False)

print(df)

   Col0  Col1  Col2
0     1     4     7
1     2     5     8
2     3     6     9

答案 6 :(得分:0)

我不想导入csv以外的任何内容,并且我所有的列表都具有相同数量的项目。此处的最高答案似乎是使列表各成一行,而不是各成一列。因此,我在这里得到了答案,并提出了以下建议:

import csv
list1 = ['a', 'b', 'c', 'd', 'e']
list2 = ['f', 'g', 'i', 'j','k']
with open('C:/test/numbers.csv', 'wb+') as myfile:
    wr = csv.writer(myfile)
    wr.writerow(("list1", "list2"))
    rcount = 0
    for row in list1:
        wr.writerow((list1[rcount], list2[rcount]))
        rcount = rcount + 1
    myfile.close()