others - 将python 列表的列表写入csv文件

我有一长串清单,下面列出了----


a = [[1.2,'abc',3],[1.2,'werew',4],........,[1.4,'qew',2]]

换句话说,列表中的值是不同类型的--浮点,


1.2,abc,3
1.2,werew,4
.
.
.
1.4,qew,2

时间:

pythoncsv模块可以轻松处理此问题:


import csv

with open("output.csv","wb") as f:
 writer = csv.writer(f)
 writer.writerows(a)

假设列表被定义为a,因为它在你的问题中,你可以通过csv.writer()的各种可选参数来调整输出的精确格式,如上面链接的库参考页面所示。


import csv
with open(file_path, 'a') as outcsv: 
 #configure writer to write standard csv file
 writer = csv.writer(outcsv, delimiter=',', quotechar='|', quoting=csv.QUOTE_MINIMAL, lineterminator='n')
 writer.writerow(['number', 'text', 'number'])
 for item in list:
 #Write item to outcsv
 writer.writerow([item[0], item[1], item[2]])

官方文档:http://docs.python.org/2/library/csv.html

对于numpy数组,Ambers的解决方案也适用:


from pylab import *
import csv

array_=arange(0,10,1)
list_=[array_,array_*2,array_*3]
with open("output.csv","wb") as f:
 writer = csv.writer(f)
 writer.writerows(list_)

你可以使用pandas:


In [1]: import pandas as pd

In [2]: a = [[1.2,'abc',3],[1.2,'werew',4],[1.4,'qew',2]]

In [3]: my_df = pd.DataFrame(a)

In [4]: my_df.to_csv('my_csv.csv', index=False, header=False)

如果出于任何原因,你都希望手动执行(不使用csvpandasnumpy等等模块):


with open('myfile.csv','w') as f:
 for sublist in mylist:
 for item in sublist:
 f.write(item + ',')
 f.write('n')

当然,滚动自己的版本可能是错误的,而且效率低下,这通常就是为什么有一个模块,但是,有时写你自己可以帮助你理解它们的工作方式,有时它只是简单的。

请确保在创建作者时指示lineterinator='n' ; 否则,当数据源来自其他csv文件时,可能会在每个数据行之后,写入一个额外的空行。

以下是我的解决方案:


with open('csvfile', 'a') as csvfile:
 spamwriter = csv.writer(csvfile, delimiter=' ',quotechar='|', quoting=csv.QUOTE_MINIMAL, lineterminator='n')
for i in range(0, len(data)):
 spamwriter.writerow(data[i])

...