python 如何读、写、解析CSV文件


Posted in Python onMarch 03, 2021

您知道将表格数据存储到纯文本文件背后的机制是什么吗?答案是CSV(逗号分隔值)文件,该文件允许将数据转换为纯文本格式。在这篇文章中关于“在Python如何阅读CSV文件”中,我们将学习如何读,写和解析的CSV文件的Python。

将详细讨论以下方面:

  • 什么是CSV文件及其用途?
  • 为什么使用CSV文件格式?
  • Python CSV模块

                 CSV模块功能

  • 在Python中执行写入,读取CSV文件的操作
  • 让我们开始吧。

什么是CSV文件及其用途?

CSV(逗号分隔值)是一种纯文本文件格式,用于存储表格数据(例如电子表格或数据库)。它本质上存储的表格数据包括数字和纯文本。大多数在线服务使用户可以自由地将网站中的数据导出为CSV文件格式。CSV文件通常会在Excel中打开,几乎所有数据库都具有不同的特定工具以允许导入相同的文件。

文件的每一行都称为记录。每个记录由用逗号分隔 的字段组成,这些字段也称为“定界符”,这是默认定界符,其他记录包括pipe(|),分号(;)。下面给出的是一个普通CSV文件的结构,以逗号分隔,我正在使用一个泰坦尼克号CSV文件。

结构

Passenger,Id,Survived,Pclass,Name,Sex.Age
1,0,3 Braund, Mr. Owen Harris ,male, 22
2,1,1 Cumings, Mrs. John Bradley (Florence Briggs Thayer), female,38
3,1,3 Heikkinen, Miss. Laina ,female, 26
4,1,1 Futrelle, Mrs. Jacques Heath (Lily May Peel),female,35

继续说说使用CSV文件格式的原因。

为什么使用CSV文件格式?

CSV是纯文本文件,它使数据交换更容易,也更易于导入到电子表格或数据库存储中。例如:您可能希望将某个统计分析的数据导出到CSV文件,然后将其导入电子表格以进行进一步分析。总体而言,它使用户可以通过编程轻松地体验工作。任何支持文本文件或字符串操作的语言(例如Python)都可以直接使用CSV文件。

继续前进,让我们看看Python如何原生使用CSV。

Python CSV模块

Python使用的CSV软件包是标准库的一部分,因此您无需安装它。

import csv

现在,让我向您展示不同的CSV功能。

CSV模块功能

在CSV模块下,您可以找到以下功能:

python 如何读、写、解析CSV文件

让我们继续前进,从Python CSV文件上不同操作的编码角度来看。

Python中CSV文件的操作

加载CSV文件后,您可以执行多种操作。我将在Python中显示对CSV文件的读取和写入操作。

在Python中读取CSV文件:

import csv 
 
with open('Titanic.csv','r') as csv_file: #Opens the file in read mode
  csv_reader = csv.reader(csv_file) # Making use of reader method for reading the file
 
  for line in csv_reader: #Iterate through the loop to read line by line
    print(line)

输出:

python 如何读、写、解析CSV文件

在这里,从输出中可以看到,我已经使用了Titanic CSV File。并且所有字段都用逗号分隔,文件被读入Python。

继续前进,让我们看看如何写入CSV文件。

用Python写入CSV文件:

import csv
 
with open('Titanic.csv', 'r') as csv_file:
  csv_reader = csv.reader(csv_file)
 
  with open('new_Titanic.csv', 'w') as new_file: # Open a new file named 'new_titanic.csv' under write mode
    csv_writer = csv.writer(new_file, delimiter=';') #making use of write method
 
    for line in csv_reader: # for each file in csv_reader
      csv_writer.writerow(line) #writing out to a new file from each line of the original file

out:

python 如何读、写、解析CSV文件

现在,这种使用读写器方法处理CSV文件的方法是最常见的方法之一。让我们继续前进,看看如何使用python字典来做同样的事情。

读取CSV文件作为字典:

import csv 
 
with open('Titanic.csv','r') as csv_file: #Open the file in read mode
  csv_reader = csv.DictReader(csv_file) #use dictreader method to reade the file in dictionary
 
  for line in csv_reader: #Iterate through the loop to read line by line
    print(line)

输出:

python 如何读、写、解析CSV文件

从输出中可以看到,字段已被替换,它们现在充当字典的“键”。

让我们看看如何将CSV文件作为字典写入。

作为字典写入CSV文件

import csv 
 
mydict = [{'Passenger':'1', 'Id':'0', 'Survived':'3'}, #key-value pairs as dictionary obj
     {'Passenger':'2', 'Id':'1', 'Survived':'1'},
     {'Passenger':'3', 'Id':'1', 'Survived':'3'}]
 
fields = ['Passenger', 'Id', 'Survived'] #field names
 
filename = 'new_Titanic.csv' #name of csv file
 
with open('new_Titanic.csv', 'w')as new_csv_file: #open a new file 'new_titanic,csv' under write mode
  writer = csv.DictWriter(new_csv_file, fieldnames=fields) 
  writer.writeheader() #writing the headers(field names)
 
  writer.writerows(mydict) #writing data rows

输出:

python 如何读、写、解析CSV文件

让我们看看如何在python中将CSV文件读取为熊猫。

以熊猫格式读取CSV文件:

import pandas #install pandas package
 
result = pandas.read_csv('Titanic.csv') #read the csv file
 
print(result) # print result

输出:

python 如何读、写、解析CSV文件

这使我们到文章“如何在Python中读取CSV文件”的结尾。我希望您对与CSV相关的所有概念,如何读写它,如何将CSV作为字典进行读写以及如何将CSV作为熊猫进行阅读都一目了然。

确保尽可能多地练习并恢复经验。

以上就是python 如何读、写、解析CSV文件的详细内容,更多关于python 读写解析CSV文件的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
零基础写python爬虫之抓取百度贴吧并存储到本地txt文件改进版
Nov 06 Python
在Python的Flask框架中实现单元测试的教程
Apr 20 Python
python实现简单的socket server实例
Apr 29 Python
python计算方程式根的方法
May 07 Python
Python2.x版本中cmp()方法的使用教程
May 14 Python
Python中将字典转换为XML以及相关的命名空间解析
Oct 15 Python
Python3爬虫爬取百姓网列表并保存为json功能示例【基于request、lxml和json模块】
Dec 05 Python
python 对字典按照value进行排序的方法
May 09 Python
python单例设计模式实现解析
Jan 07 Python
使用celery和Django处理异步任务的流程分析
Feb 19 Python
django queryset 去重 .distinct()说明
May 19 Python
基于PyTorch中view的用法说明
Mar 03 Python
聊聊python在linux下与windows下导入模块的区别说明
Mar 03 #Python
python 递归相关知识总结
Mar 03 #Python
使用pandas读取表格数据并进行单行数据拼接的详细教程
Mar 03 #Python
用gpu训练好的神经网络,用tensorflow-cpu跑出错的原因及解决方案
Mar 03 #Python
神经网络训练采用gpu设置的方式
Mar 03 #Python
解决TensorFlow训练模型及保存数量限制的问题
Mar 03 #Python
使paramiko库执行命令时在给定的时间强制退出功能的实现
Mar 03 #Python
You might like
人大复印资料处理程序_查询篇
2006/10/09 PHP
基于PHP array数组的教程详解
2013/06/05 PHP
ThinkPHP惯例配置文件详解
2014/07/14 PHP
非集成环境的php运行环境(Apache配置、Mysql)搭建安装图文教程
2016/04/12 PHP
Yii2组件之多图上传插件FileInput的详细使用教程
2016/06/20 PHP
onsubmit阻止form表单提交与onclick的相关操作
2010/09/03 Javascript
百度移动版的url编码解码示例
2014/04/29 Javascript
使用console进行性能测试
2015/04/27 Javascript
jQuery实现鼠标单击网页文字后在文本框显示的方法
2015/05/06 Javascript
vue插件tab选项卡使用小结
2016/10/27 Javascript
Vue 进入/离开动画效果
2017/12/26 Javascript
javascript canvas封装动态时钟
2020/09/30 Javascript
vue 导航守卫和axios拦截器有哪些区别
2020/12/19 Vue.js
[47:26]完美世界DOTA2联赛 LBZS vs Forest 第二场 11.07
2020/11/09 DOTA
Python中绑定与未绑定的类方法用法分析
2016/04/29 Python
Python设计模式之中介模式简单示例
2018/01/09 Python
Python安装模块的常见问题及解决方法
2018/02/05 Python
关于python列表增加元素的三种操作方法
2018/08/22 Python
python判断列表的连续数字范围并分块的方法
2018/11/16 Python
对Python3使运行暂停的方法详解
2019/02/18 Python
用Python徒手撸一个股票回测框架搭建【推荐】
2019/08/05 Python
使用Python获取当前工作目录和执行命令的位置
2020/03/09 Python
Python连接HDFS实现文件上传下载及Pandas转换文本文件到CSV操作
2020/06/06 Python
python解压zip包中文乱码解决方法
2020/11/27 Python
HTML5梦幻之旅——炫丽的流星雨效果实现过程
2013/08/06 HTML / CSS
英国著名的药妆网站:Escentual
2016/07/29 全球购物
PHP高级工程师面试问题推荐
2013/01/18 面试题
人事专员岗位职责说明书
2014/07/30 职场文书
班级出游活动计划书
2014/08/15 职场文书
银行授权委托书格式
2014/10/10 职场文书
党的群众路线教育实践活动心得体会范文
2014/11/05 职场文书
新党章的学习心得体会
2014/11/07 职场文书
医院保洁员岗位职责
2015/02/13 职场文书
生产现场禁烟通知
2015/04/23 职场文书
毕业论文答辩演讲稿
2015/06/23 职场文书
Python制作表白爱心合集
2022/01/22 Python