Python中CSV文件的读与写(python中csv文件读取)
off999 2024-10-28 16:53 83 浏览 0 评论
CSV 是一种以纯文本形式存储表格数据的文件,由于其数据一般使用逗号分割因此里边的 C 代表的就是 Comma,逗号的意思。但是,使用逗号分割并不是必须的,也可以使用制表符或其他符号分割。
在 Python 中提供了标准库 csv 模块来支持完整的功能。本文将详细讲解 csv 的读取与写入。
Python 写入 CSV
以下是一个简单的写入案例:
import csv
with open("data.csv", "w") as f:
writer = csv.writer(f)
writer.writerow(["Name", "Age", "Country"])
writer.writerow(["John", 25, "USA"])
writer.writerow(["Mary", 20, "Canada"])如上述代码中,我们先打开一个文件 data.csv,并设置为 w(写)模式,然后调用 csv.writer 方法,将 f 对象传入,使用writer.writerow 来设置内容,就可以将数据写入到 csv 中,效果如下图。
空行问题
在运行结果中可以看到, 数据之间会有一行空行,这个也非常容易处理,只需要在文件处设置 newline=""即可
open("data.csv", "w", newline="")替换分隔符
上边代码中,默认使用逗号作为分隔符,正如前边所说,CSV 中可以使用其他符号做为分隔符,因此需要在初始化 CSV 对象时,使用delimiter参数指定分隔符类型。
import csv
with open("data.csv", "w", newline="") as f:
writer = csv.writer(f, delimiter=" ")
writer.writerow(["Name", "Age", "Country"])
writer.writerow(["John", 25, "USA"])
writer.writerow(["Mary", 20, "Canada"])如上述代码,我们使用空格做为分隔符,运行结果如下
但是需要注意的是,修改分隔符后,如果使用 wps 或 Word 文档打开需要重新设置分隔符,否则就会导致其无法准确分割文件中内容。如下,wps 在没有重新设置分隔符就将每行数据认为是一个整的数据内容。
writerow 和writerows 区别
两个方法都是写入行内容,其中writerow 用来写入一行内容,writerows 用来写入多行内容。
writer.writerow(["Name", "Age", "Country"])
writer.writerows([["Name", "Age", "Country"],
["John", 25, "USA"],
["Mary", 20, "Canada"]])使用字典写入
在做爬虫数据时,更多的是将字典数据保存起来,因此 Python 中提供了 DictWriter 方法来实现此功能。
import csv
with open("data.csv", "w", newline="") as f:
# 初始化
writer = csv.DictWriter(f, fieldnames=["name", "age", "city"])
# 写入头信息
writer.writeheader()
writer.writerow({"name": "John", "age": 20, "city": "New York"})
writer.writerow({"name": "Jane", "age": 25, "city": "Los Angeles"})
writer.writerow({"name": "Jim", "age": 30, "city": "Chicago"})如上述代码中,使用DictWriter 初始化,传入文件对象,并设置标题名,需要注意的是,这里设置标题后(用于指定字典的 key 值),还需要调用writeheader()才可以,否则在文件中无法写入标题内容,写入内容同样使用writerow 方法,但是参数需要是字典类型数据,并且字典 key 值需要和初始化时指定的一致。写入效果如下:
Python 读取 CSV
在上边使用完了写入的各种方法后,我们来看看如何读取 csv 文件内容。
import csv
with open("data.csv", "r") as f:
reader = csv.reader(f)
for row in reader:
print(row)
# ['name', 'age', 'city']
# ['John', '20', 'New York']
# ['Jane', '25', 'Los Angeles']
# ['Jim', '30', 'Chicago']如上述代码中,使用 csv 中的 reader 方法即可完成数据的读取。
可以看出,读取到的数据也仅仅是将每行的数据整理到了数组中,因此如果需要将数据整理到字典中,还需要更多的逻辑来完成,如下使用DictReader 来读取,并将数据读取到一个字典中。
import csv
with open('data.csv', 'r') as file:
csv_reader = csv.DictReader(file)
data = [{'name': row['name'],
'age': row['age'],
'city': row['city']}
for row in csv_reader]
print(data)
# [{'name': 'John', 'age': '20', 'city': 'New York'},
# {'name': 'Jane', 'age': '25', 'city': 'Los Angeles'},
# {'name': 'Jim', 'age': '30', 'city': '芝加哥'}]还有一种更为简便的方法,使用 pandas 来完成,这里不做过多的展开,后续介绍到 pandas 库时再详细说明。
import pandas as pd
# 读取CSV文件并将数据转换为字典
data = pd.read_csv('data.csv').to_dict(orient='records')
print(data)相关推荐
-
- 百度云网页版登录入口(百度网盘网页版登录18581113484212054.5929.3810549)
-
先登录网页版试一试,一般都会有提示。百度网盘客户端不能登录原因有很多:1不能用第三方账号登陆,否则登录失败。2没有绑定手机3百度网盘客户端用的以前旧版本,下载安装最新版4存储了违规文件被系统封禁,需要先解封,再来登陆。手机登陆云盘...
-
2026-01-19 18:51 off999
- 源码网(源码网棋牌力荐双击玩.安卓应用更新链接.org)
-
统一机构代码查询官网https://www.cods.org.cn/gscx/产品标准号查询官网:国家质量技术监督管理局产品编码中心官方网站网采代码是指可以把它理解成源文代码,就拿我们看到的这个网页举...
- 7723游戏官网入口(7723游戏盒官方正版)
-
要登录和下载游戏,你需要按照以下步骤操作:首先,确保你已经安装了7723游戏盒应用程序。然后,打开应用程序并点击登录按钮。输入你的用户名和密码,如果你还没有账号,可以点击注册按钮创建一个新账号。完成登...
- 谷歌安卓版app下载(谷歌paypal官网注册入口)
-
手机系统软件闪退或者第三方软件闪退,可以查看以下几种原因:一、清理后台程序;我们在使用完一个软件的时候,习惯性的返回到桌面,经常没有真正退出程序,而程序还在后台运行,当后台程序过多时,就可能导致闪退。...
- qq手游下载(手游版qq)
-
要知道一个游戏的原文件大小,可以按照以下步骤:1.在应用商店下载并安装该游戏。2.进入手机的“设置”界面,然后点击“应用管理”或“应用程序”。3.找到并点击游戏应用。4.在游戏应用信息页面中,可以看到...
- 唱歌软件哪个最好用(哪款唱歌软件好用又免费)
-
k歌软件的《全民K歌》最好。推出较早的一款K歌软件,在功能上还是包含比较多的,全民K歌基于用户需求打造的线上K歌工具,不仅提供了海量版权曲库,还不断迭代AI智能评分、AI智能修音等先进黑科技,用专业的...
- 迅雷7苹果官方下载(迅雷官方下载苹果最新版本)
-
1、建议您在迅雷软件主界面右上角点击倒三角,在菜单中进入迅雷下载诊断工具,诊断下是否有浏览器支持相关的问题。2、在浏览器管理加载项里面看下是否开启了迅雷下载支持,如未启用请点击启用即可。3、可能是在安...
- 在线设计logo商标免费(logo在线设计网)
-
你好,注册费用按类别按个数收取,每类每个商标费用:1、一般商标每件300元(十年有效期,含十年的费用,国内公司或个人,其中国家规费300元);2、代理机构网报一般商标每件1000元(十年有效期,含十年...
- 如何快速学会ps软件(怎么学好ps软件,会简单的就好)
-
1.Photoshop只是一个工具而已,不要想的那么难2.基础是让你们最容易忽略的,但是必须牢固3.多去分析优秀作品,总结经验,技巧4.看作品尝试用不同的方法制作5.不需掌握PS所有功能,熟悉和工作相...
- 三国群雄传(三国群雄传2)
-
三国群英传2游戏中,分为五个时期,每个时期的君主数量不等,但主角还是曹操、孙权、刘备,几乎这三人在几个时期都是需要励精图治的时期。而刘备是很多人同情的一个贤明君主,因为从三国开端到三足鼎立时期,刘备都...
- 360官网电脑版(360官方网页)
-
http://hao.360.cn/360导航--一个主页,整个世界,为用户提供门户、新闻、视频、游戏、小说、彩票等各种分类的优秀内容和网站入口,提供简单便捷的上网导航服务。1.不是官方网站。2....
- nba免费直播高清jrs免(nba直播在线观看高清jrs)
-
由于美国和中国之间贸易战的原因,和火箭总裁的出言不逊,导致中国和NBA的播放停止。所以不能观看,等到后期和解后可以继续观看!祝你好运!有高清的,看NBA还是挺好的。方法一:JRS直播1、JRS直播是一...
- pc游戏模拟器(pc游戏模拟器推荐)
-
目前,PC游戏模拟器中最受欢迎和认可的是著名的BlueStacks。它是一款免费的安卓模拟器,可以在电脑上运行各种安卓游戏和应用程序。BlueStacks具有卓越的性能和稳定性,提供了流畅的游戏体验,...
- 炉石传说手游官网下载(炉石传说手游官网下载国服)
-
要下载炉石传说端游,可前往该游戏的官方网站或Blizzard官网,从中下载安装程序并安装。同时,玩家也可在国内的一些游戏下载网站上下载该游戏的安装包,但需保证其来源可靠。另外,在下载安装游戏时,可根据...
欢迎 你 发表评论:
- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
