python读取CSV文件以及“写入CSV致文件每一行后面会多一个空行”问题解决
2018-02-24 18:05
1021 查看
原文链接:python读取CSV文件
python中有一个读写csv文件的包,直接import csv即可。利用这个python包可以很方便对csv文件进行操作,一些简单的用法如下。1. 读文件
输出结果如下['0.093700','0.139771','0.062774','0.007698']['-0.022711','-0.050504','-0.035691','-0.065434']['-0.090407','0.021198','0.208712','0.102752']['-0.085235','0.009540','-0.013228','0.094063']可见csv_reader把每一行数据转化成了一个list,list中每个元素是一个字符串。
2. 写文件读文件时,我们把csv文件读入列表中,写文件时会把列表中的元素写入到csv文件中。
链接:http://blog.csdn.net/lixiang0522/article/details/7755059其他链接:python读写csv
python中有一个读写csv文件的包,直接import csv即可。利用这个python包可以很方便对csv文件进行操作,一些简单的用法如下。1. 读文件
csv_reader = csv.reader(open('data.file', encoding='utf-8')) for row in csv_reader: print(row)例如有如下的文件
输出结果如下['0.093700','0.139771','0.062774','0.007698']['-0.022711','-0.050504','-0.035691','-0.065434']['-0.090407','0.021198','0.208712','0.102752']['-0.085235','0.009540','-0.013228','0.094063']可见csv_reader把每一行数据转化成了一个list,list中每个元素是一个字符串。
2. 写文件读文件时,我们把csv文件读入列表中,写文件时会把列表中的元素写入到csv文件中。
list = ['1', '2','3','4'] out = open(outfile, 'w') csv_writer = csv.writer(out) csv_writer.writerow(list)可能遇到的问题:直接使用这种写法会导致文件每一行后面会多一个空行。解决办法如下:
out = open(outfile, 'w', newline='') csv_writer = csv.writer(out, dialect='excel') csv_writer.writerow(list)参考如下:在stackoverflow上找到了比较经典的解释,原来 python3里面对 str和bytes类型做了严格的区分,不像python2里面某些函数里可以混用。所以用python3来写wirterow时,打开文件不要用wb模式,只需要使用w模式,然后带上newline=''。
3down vote | In Python 2.X, it was required to open the csvfile with 'b' because the csv module does its own line termination handling.In Python 3.X, the csv module still does its own line termination handling, but still needs to know an encoding for Unicode strings. The correct way to open a csv file for writing is:outputfile=open("out.csv",'w',encoding='utf8',newline='') encodingcan be whatever you require, but newline=''suppresses text mode newline handling. On Windows, failing to do this will write \r\r\n file line endings instead of the correct \r\n. This is mentioned in the 3.X csv.reader documentation only, but csv.writer requires it as well. |
相关文章推荐
- python写入csv文件中文乱码问题解决办法
- 解决csv.writer写入文件有多余的空行问题
- python中写入csv,excel显示、pandas读取csv文件的编码问题
- Python读取某个目录下的zip压缩包解压开后计算每个小文件的md5值,并将压缩包名字、里面小文件名字、以及对应的md5值写入csv文件
- sublime python3中读取和写入文件时如何解决编码问题
- 写入文件以及解决文件名中文乱码问题
- 用python urllib2.urlopen(fileurl) 读取网络文件问题解决
- java中的文件读取和文件写出:如何从一个文件中获取内容以及如何向一个文件中写入内容
- python读取 .txt 文本内容以及将程序执行结果写入txt文件
- python写入mysql时候 出现'latin-1' codec can't encode character 问题解决方法 以及python设置utf-8
- Python3使用csv模块csv.writer().writerow()保存csv文件,产生空行的问题
- PHP自带函数fgetcsv读取csv文件中文乱码问题解决办法
- python将对象写入文件,以及从文件中读取对象
- 将数据写入到CSV文件中--出现“科学计数法”问题,已解决
- 关于python3中写入csv文件多余空行
- python 在excel文件中写入date日期数据,以及读取excel日期数据,如何在python中正确显示date日期。
- Java对象序列化文件追加对象的问题,以及Java的读取多个对象的问题解决方法。
- 如何从内核模式设备驱动程序中打开一个文件以及如何读取或写入文件(来自微软官网)
- Java底层代码实现单文件读取和写入(解决中文乱码问题)
- php读取csv文件后,uft8 bom导致在页面上显示出现问题的解决方法