我试图用Python列表中的值创建一个.csv文件。当我打印列表中的值时,它们都是unicode(?),即它们看起来像这样
[u'value 1', u'value 2', ...]
如果我遍历列表中的值,即mylist中的v:打印v,它们看起来是纯文本。
然后在每一个之间加上print '。join(mylist)
我可以输出到一个文件,即。
myfile = open(...)
print >>myfile, ','.join(mylist)
但是我想输出到CSV,并在列表中的值周围有分隔符。
"value 1", "value 2", ...
我找不到一个简单的方法来包括在格式分隔符,例如,我已经尝试通过连接语句。我该怎么做呢?
我发现最好的选择是使用numpy模块中的savetxt:
import numpy as np
np.savetxt("file_name.csv", data1, delimiter=",", fmt='%s', header=header)
以防你有多个需要堆叠的列表
np.savetxt("file_name.csv", np.column_stack((data1, data2)), delimiter=",", fmt='%s', header=header)
下面是另一个不需要csv模块的解决方案。
print ', '.join(['"'+i+'"' for i in myList])
例子:
>>> myList = [u'value 1', u'value 2', u'value 3']
>>> print ', '.join(['"'+i+'"' for i in myList])
"value 1", "value 2", "value 3"
但是,如果初始列表包含一些“,则不会转义。如果需要,可以调用一个函数像这样转义它:
print ', '.join(['"'+myFunction(i)+'"' for i in myList])