1、csv简介

CSV (Comma Separated Values),即逗号分隔值(也称字符分隔值,因为分隔符可以不是逗号),是一种常用的文本

格式,用以存储表格数据,包括数字或者字符。很多程序在处理数据时都会碰到csv这种格式的文件,它的使用是比

较广泛的(Kaggle上一些题目提供的数据就是csv格式),csv虽然使用广泛,但却没有通用的标准,所以在处理csv

格式时常常会碰到麻烦,幸好python内置了csv模块。下面简单介绍csv模块中最常用的一些函数。

2、csv模块中的函数

  • reader(csvfile, dialect=‘excel’, **fmtparams)

参数说明:

csvfile,必须是支持迭代(Iterator)的对象,可以是文件(file)对象或者列表(list)对象,如果是文件对
象,打开时需要加"b"标志参数。

dialect,编码风格,默认为excel的风格,也就是用逗号(,)分隔,dialect方式也支持自定义,通过调用register_dialect方法来注册,下文会提到。

fmtparam,格式化参数,用来覆盖之前dialect对象指定的编码风格。

import csv
with open('test.csv','rb') as myFile:  lines=csv.reader(myFile)  for line in lines:  print line

'test.csv’是文件名,‘rb’中的r表示“读”模式,因为是文件对象,所以加‘b’。open()返回了一个文件对象

myFile,reader(myFile)只传入了第一个参数,另外两个参数采用缺省值,即以excel风格读入。reader()返回一个

reader对象lines,lines是一个list,当调用它的方法lines.next()时,会返回一个string。上面程序的效果是将csv

文件中的文本按行打印,每一行的元素都是以逗号分隔符’,'分隔得来。

在我的test.csv文件中,存储的数据如图:


程序输出:

['1', '2']
['3', 'a']
['4', 'b']

补充:reader对象还提供一些方法:line_num、dialect、next()

  • writer(csvfile, dialect=‘excel’, **fmtparams)

参数的意义同上,这里不赘述,直接上例程:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:579817333
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
with open('t.csv','wb') as myFile:      myWriter=csv.writer(myFile)  myWriter.writerow([7,'g'])  myWriter.writerow([8,'h'])  myList=[[1,2,3],[4,5,6]]  myWriter.writerows(myList)

'w’表示写模式。

首先open()函数打开当前路径下的名字为’t.csv’的文件,如果不存在这个文件,则创建它,返回myFile文件对象。

csv.writer(myFile)返回writer对象myWriter。

writerow()方法是一行一行写入,writerows方法是一次写入多行。

注意:如果文件’t.csv’事先存在,调用writer函数会先清空原文件中的文本,再执行writerow/writerows方法。

补充:除了writerow、writerows,writer对象还提供了其他一些方法:writeheader、dialect

  • register_dialect(name, [dialect, ]**fmtparams)

这个函数是用来自定义dialect的。

参数说明:

name,你所自定义的dialect的名字,比如默认的是’excel’,你可以定义成’mydialect’

[dialect, ]**fmtparams,dialect格式参数,有delimiter(分隔符,默认的就是逗号)、quotechar、

quoting等等,可以参考Dialects and Formatting Parameters

csv.register_dialect('mydialect',delimiter='|', quoting=csv.QUOTE_ALL)

上面一行程序自定义了一个命名为mydialect的dialect,参数只设置了delimiter和quoting这两个,其他的仍然采用

默认值,其中以’|'为分隔符。接下来我们就可以像使用’excel’一样来使用’mydialect’了。我们来看看效果:

在我test.csv中存储如下数据:.

以’mydialect’风格打印:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:579817333
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
with open('test.csv','rb') as myFile:  lines=csv.reader(myFile,'mydialect')  print lines.line_num  for line in lines:  print line

输出:

['1,2', '3']
['4,5', '6']

可以看到,现在是以’|'为分隔符,1和2合成了一个字符串(因为1和2之间的分隔符是逗号,而mydialect风格的分隔

符是’|’),3单独一个字符串。

对于writer()函数,同样可以传入mydialect作为参数,这里不赘述。

  • unregister_dialect(name)

这个函数用于注销自定义的dialect

此外,csv模块还提供get_dialect(name)、list_dialects()、field_size_limit([new_limit])等函数,这些都比较

简单,可以自己试试。比如list_dialects()函数会列出当前csv模块里所有的dialect:

print csv.list_dialects()

输出:

['excel-tab', 'excel', 'mydialect']

'mydialect’是自定义的,‘excel-tab’, 'excel’都是自带的dialect,其中’excel-tab’跟’excel’差不多,

只不过它以tab为分隔符。

csv模块还定义了

一些类:DictReader、DictWriter、Dialect等,DictReader和DictWriter类似于reader和writer。

一些常量:QUOTE_ALL、QUOTE_MINIMAL、.QUOTE_NONNUMERIC等,这些常量可以作为Dialects and Formatting Parameters的值。

Python csv模块的使用相关推荐

  1. python csv 模块的使用

    python csv 模块的使用 歌曲推荐:攀登(live) csv 是用逗号分隔符来分隔列与列之间的. 1. csv的写入 1.简单的写入,一次写入一行 import csv with open(& ...

  2. python csv模块 reader_Python的CSV模块

    Python 的 CSV模块的使用方法,包括,reader, writer, DictReader, DictWriter.register_dialect 一直非常喜欢python的csv模块,简单 ...

  3. python csv模块 reader_Python之csv模块

    简介 csv文件具有格式简单,快速存取,兼容性好等特点,工程.金融.商业等很多数据文件都是采用csv文件保存和处理.工作中数据处理也用到了csv,简要总结下使用经验,特别是那些由于本地兼容性导致的与官 ...

  4. python csv模块心得

    2019独角兽企业重金招聘Python工程师标准>>> with open('tiger.csv', 'wb') as csvfile:writer = csv.writer(csv ...

  5. python csv模块 一次读多行_python中csv模块读取reader只能读取一次

    各位好,请问python读取csv文件时只能读取一次是为什么 现在有一个csv文件 大概是这个样子 现在对ID和length进行读取 import csv with open('ccc.csv','r ...

  6. python csv模块追加列,使用Python在CSV上添加新列

    I have the following list of numbers: ['Number', 1,2,3,4] If I have the following CSV file: `Name` ` ...

  7. python csv模块用法_python使用csv模块如何将数据存放在一张表的不同行?

    def save2csv(file_name=None, header=None, data=None): """ 保存成CSV格式文件,方便Excel直接打开 :par ...

  8. python csv模块 防止重复写入标题

    #newline的作用是防止每次插入都有空行 with open("test.csv", "a+", newline='') as csvfile:writer ...

  9. csv java web 导入_DAY5-step9 使用CSV模块和Pandas在Python中读取和写入CSV文件

    什么是CSV文件? CSV文件是一种纯文本文件,其使用特定的结构来排列表格数据. CSV是一种紧凑,简单且通用的数据交换通用格式. 许多在线服务允许其用户将网站中的表格数据导出到CSV文件中. CSV ...

最新文章

  1. python内置库之学习ctypes库(一)
  2. 关于Android 8.0java.lang.SecurityException: Permission Denial错误的解决方法
  3. 洛谷P3168 [CQOI2015]任务查询系统 [主席树,差分]
  4. tf.reshape的-1的错误理解
  5. 直播预告 | 东南大学周张泉:基于知识图谱的推理技术
  6. 没有测量,就没有管理
  7. POJ2503 Babelfish map或者hash_map
  8. 深入 JavaScript(4) - new运算符是如何工作的
  9. 12如何隐藏dock栏_ iOS 13 隐藏 Dock栏,一张神奇壁纸就可以
  10. Excel-DNA开发包:ExcelDna-0.34.6.zip下载
  11. Ubuntu Server 16.04.x进入中文安装界面无法安装busybox-initramfs
  12. 城市大脑 —— 数据重塑城市未来
  13. 联想台式主机拆机教程_联想一体机拆机图解 联想一体机电脑该怎么拆机
  14. NLP:不要重新造轮子
  15. GC问题排查实战三-Parallel Scavenge和Parallel Old日志分析
  16. arm学习方法(转)
  17. 如何让ffplay或者ffmpeg支持H265编码的rtmp/http-flv 实时直播流
  18. 等级保护测评策略建议整改措施
  19. 值得一看!2018年最优秀的9个Android Material Design Apps!
  20. Linux 使用for循环结构

热门文章

  1. 45个实用的JavaScript黑科技
  2. 人工智能的策略,如果国家优先发展”梦想成真”?
  3. Python遍历目录的4种方法
  4. C# 程序运行耗时测试类
  5. 如何查看SE16N修改的表的记录
  6. SAP概念之利润中心
  7. 删除前导0后缀0的几种方法
  8. 一个程序员的时间管理
  9. 设置SAP登录后的背景图片(很有意思)
  10. 百度2020Q3财报:“十四五”规划注入新动能,百度智能云驶入快车道