零基础也能看懂的python内置csv模块教程
作者:梦想橡皮擦 发布时间:2023-01-06 14:03:16
csv(Comma-Separated Values)文件是什么?
它是一种文件格式,一般也被叫做逗号分隔值文件,可以使用 Excel 软件或者文本文档打开 。
其中数据字段用半角逗号间隔(也可以使用其它字符),使用 Excel 打开时,逗号会被转换为分隔符。
csv 文件是以纯文本形式存储了表格数据,并且在兼容各个操作系统。
例如下面的文本,在 excel 中就以表格的形式存在。
sid,name,age
10010,橡皮擦,18
10086,发量迷人的乔喻,19
10000,各位博主,20
下面就对 python 内置模块 csv 的用法进行简单的说明。
python 中的 csv 文件清晰解法
读取文件
使用 csv.reader()
读取 csv 文件内容。
import csv # 模块导入
with open('aa.csv', 'r', newline='', encoding='utf-8') as f:
# <_csv.reader object at 0x00000000020918D0>
reader = csv.reader(f)
for r in reader:
print(r)
其中 csv.reader()
方法的原型如下所示:
csv.reader(csvfile, dialect='excel', **fmtparams)
其中的参数 csvfile
可以是任何对象,但要求该对象是一个迭代器,所以文件对象和列表对象都可以传入,如果是文件对象,还要求打开它时携带参数 newline=''
。后面的参数保持默认即可。
第二种方式是使用 DictReader
类,该类实现的效果与 reader()
方法一致,也是接收可迭代对象,返回生成器,差异是将返回的结果放到了一个字典的值内,字典的键就是单元格的标题。并且这样输出的函数是,不需要单独处理 csv 的列头行了。
import csv # 模块导入
with open('aa.csv', 'r', newline='', encoding='utf-8') as f:
reader = csv.DictReader(f)
for r in reader:
print(r)
输出内容:
OrderedDict([('sid', '10010'), ('name', '橡皮擦'), ('age', '18')])
OrderedDict([('sid', '10086'), ('name', '发量迷人的乔喻'), ('age', '19')])
OrderedDict([('sid', '10000'), ('name', '各位博主'), ('age', '20')])
写入文件
csv 文件写入用到的模块方法是 csv.writer()
,该方法的原型如下:
csv.writer(csvfile, dialect='excel', **fmtparams)
最基本的写入:
import csv
with open('abc.csv', 'w', newline='') as csvfile:
w = csv.writer(csvfile)
# 写入列头
w.writerow(["sid", "name", "age"])
w.writerow(["10010", "橡皮擦", "18"])
w.writerow(["10086", "发量迷人的乔喻", "18"])
这时如果你在打开文件时,缺少了 newline=''
,那写入 csv 文件内容之后,会出现多余的换行。
除此之外,我们写入 csv 文件的时候,可以启用 dialect
(方言)参数。例如使用 |
作为列的分隔符。
此时的文件写入代码写成下述内容:
class my_dialect(csv.Dialect):
lineterminator = '\r\n'
delimiter = ';'
quotechar = '"'
quoting = csv.QUOTE_MINIMAL
with open('abc.csv', 'w', newline='') as csvfile:
w = csv.writer(csvfile, dialect=my_dialect)
# 写入列头
w.writerow(["sid", "name", "age"])
w.writerow(["10010", "橡皮擦", "18"])
w.writerow(["10086", "发量迷人的乔喻", "18"])
上述代码定义了一个新的类 my_dialect
,并使其继承 csv.Dialect
类,重写了其中的部分字段。
delimiter
:分隔字符,默认为 ,
;
lineterminator
:writer 方法写入数据时,每行的结尾字符,默认为 \r\n
;
quotechar
:单字符,用于包裹具有特殊字符的字段,例如 定界符,引号字符,换行符,默认是 "
;
quoting
:控制 writer 何时生成引号,以及 reader 何时识别引号,默认是 QUOTE_MINIMAL
,其余几个值分别是
QUOTE_ALL(全部加引号),
QUOTE_MINIMAL(特定情况加),
QUOTE_NONNUMERIC(所有非数字加),
QUOTE_NONE(都不加);
Writer
对象的方法说明:
csvwriter.writerow(row)
:写入单行;
csvwriter.writerows(rows)
:写入多行
import csv # 模块导入
csv_headers = ['name', 'age']
rows = [('橡皮擦', 18),
('发量迷人的乔喻', 19),
('各位博主', 20)]
with open('./aa.csv', 'w', encoding='utf-8',newline='') as f:
csv_file = csv.writer(f)
csv_file.writerow(csv_headers) # 写入头
csv_file.writerows(rows)
与 DictReader
类使用方法差不多,还存在一个 DictWriter
类,该类将以字段格式写入 csv
文件字段。
import csv
with open('abc.csv', 'w', newline='') as csvfile:
w = csv.DictWriter(csvfile, fieldnames=['sid', 'name', 'age'])
w.writeheader() # 写入列头
w.writerow({'sid': '10010', 'name': '橡皮擦', 'age': 18})
w.writerow({'sid': '10010', 'name': '橡皮擦', 'age': 18})
w.writerow({'sid': '10010', 'name': '橡皮擦', 'age': 18})
上述代码尤其注意 fieldnames
参数是必填参数,表示的是列头,并且在写入正式数据前,需使用 w.writeheader()
写入列头。
csv 文件其它说明
关于 csv 方言,可以使用 csv.register_dialect
方法将 name
与 dialect
关联起来,核心含义相当于给 dialect
起了一个别名。删除也比较简单,使用 csv.unregister_dialect(name)
即可。csv.list_dialects()
返回已经注册的方言名称,你可以在电脑上做一下测试,查看 Python 环境中提供的几种方言。
import csv
csv.register_dialect('ca', delimiter='|', quoting=csv.QUOTE_MINIMAL)
with open('abc.csv', 'w', newline='') as csvfile:
w = csv.DictWriter(csvfile, fieldnames=['sid', 'name', 'age'], dialect='ca')
w.writeheader() # 写入列头
w.writerow({'sid': '10010', 'name': '橡皮擦', 'age': 18})
w.writerow({'sid': '10010', 'name': '橡皮擦', 'age': 18})
w.writerow({'sid': '10010', 'name': '橡皮擦', 'age': 18})
csv 模块还提供了 csv.Sniffer
类,用于推断 csv 文件的格式,其存在两个方法:
sniff(sample, delimiters=None):分析并返回一个 dialect 子类,可以分析出格式参数;
has_header(sample):分析 csv 文件是否存在标题。
来源:https://blog.csdn.net/hihell/article/details/121250076


猜你喜欢
- <% '************************************************
- 由于网络带宽以及某些WAP服务器DECK传输的限制,所以DECK越小越好,最好不要超过1.2K。如果你的需求很复杂,最好分成几个DECK来完
- 前言今天笔者想和大家来聊聊python接口自动化如何使用requests库发送http请求,废话呢笔者就不多说了,直接进入正题。一、requ
- Symfony2是一个基于PHP语言的Web开发框架,有着开发速度快、性能高等特点。本文以一个程序示例的实现过程详细叙述了Symfony2框
- 目录开源地址Cast是什么?为什么使用Cast?使用方式案例Example ‘ToString':Example ‘ToInt
- 这篇文章主要介绍了python实现windows桌面截图代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值
- 事件循环(Event Loop),是每个JS开发者都会接触到的概念,但是刚接触时可能会存在各种疑惑。众所周知,JS是单线程的,即同一时间只能
- /** * 类说明:对MYSQL数据库的操作类 */ using System; using System.Data; using MySq
- MVC模式MVC, 全名Model View Controller, 是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Mo
- 前言本文主要给大家介绍了关于python用MethodType绑定方法到类的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细
- 一、Set 集合类型Set 集合类型 (交差并补) 特点 :无序 , 自动去重集合用{}表示,元素间用逗号分隔建立集合类型用{}或set()
- 1、首先要配好vs开发工程注意版本;我这使用32位的python那么我vs工程这边也选择32位的编译环境去配置注意点;需要将python安装
- 演示示例使用QQ邮箱发送邮件,先获取自己的QQ邮箱的授权码。因为后面发送邮件时需要使用自己的授权码作为邮箱的密码登录邮箱最后达到发送邮件的目
- 本文实例讲述了Python自定义线程池实现方法。分享给大家供大家参考,具体如下:关于python的多线程,由与GIL的存在被广大群主所诟病,
- write2vin 的 PPT原文路宛兮写的简介:本文解释了以下问题: 1.什么是用户体验? 2.谁发明了这个术语?他想表达什么意思? 3.
- 目的在各种各样的理论计算中,常常需要绘制各种填充图,绘制完后需要加渐变填充的colorbar。可是有些软件如VMD,colorbar渲染后颜
- 解决SQL2000最大流水号的两个好方法问:请问怎样才能解决ms serer 2000 最大流水号的问题?答:我可以介绍两种方法给你:方法1
- 00 小编的问题小编向我们反馈,从微信里复制出来的图片,会被微信屏蔽,无法显示我们后天采用的是百度编辑器,而且已经做了远程图片本地化,于是检
- 效果图:代码如下:<!DOCTYPE html><html lang="en"><head
- 本文实例讲述了Golang最大递减数算法问题。分享给大家供大家参考,具体如下:给出一个非负整数,找到这个非负整数中包含的最大递减数。一个数字