Python中读写CSV文件的深入探讨

目录

一、引言

二、如何读取CSV文件

三、如何写入CSV文件

四、处理大型CSV文件

五、总结


一、引言

CSV(Comma-Separated Values)文件是一种常见的逗号分隔值格式的文件,常用于存储和传输数据。在Python中,我们可以使用内置的csv模块来读写CSV文件。通过使用csv模块,我们可以轻松地读取和写入CSV文件中的数据,并对数据进行处理和分析。

二、如何读取CSV文件

在Python中,我们可以使用csv模块的csv.reader()函数来读取CSV文件。以下是一个简单的示例代码,演示了如何读取一个名为“example.csv”的CSV文件:

import csv  
  
# 打开文件并创建csv.reader对象  
with open('example.csv', 'r') as f:  
    reader = csv.reader(f)  
  
    # 遍历csv.reader对象中的每一行数据  
    for row in reader:  
        print(row)

上述代码将打开名为“example.csv”的文件,并创建一个csv.reader对象。然后,通过遍历csv.reader对象中的每一行数据,我们可以读取文件中的所有行。每一行数据将作为一个列表返回,其中列表中的每个元素是该行中的一个字段值。

如果CSV文件中包含标题行,我们可以通过使用next()函数来跳过标题行,例如:

import csv  
  
# 打开文件并创建csv.reader对象  
with open('example.csv', 'r') as f:  
    reader = csv.reader(f)  
  
    # 跳过标题行  
    next(reader)  
  
    # 遍历csv.reader对象中的每一行数据  
    for row in reader:  
        print(row)

在上述代码中,我们使用next()函数来跳过标题行,然后遍历剩余的行。

如果CSV文件中的字段值包含逗号或其他特殊字符,可以使用csv.reader()函数的quoting参数来指定引号字符和分隔符。例如,如果字段值用双引号括起来,并且使用制表符作为分隔符,则可以使用以下代码读取该文件:

import csv  
  
# 打开文件并创建csv.reader对象,指定引号字符和分隔符  
with open('example.csv', 'r') as f:  
    reader = csv.reader(f, quoting=csv.QUOTE_ALL, delimiter='\t')  
  
    # 遍历csv.reader对象中的每一行数据  
    for row in reader:  
        print(row)

在上述代码中,我们将引号字符设置为双引号,并将分隔符设置为制表符。这样就可以正确地解析包含逗号或其他特殊字符的字段值。

三、如何写入CSV文件

在Python中,我们可以使用csv模块的csv.writer()函数来写入CSV文件。以下是一个简单的示例代码,演示了如何将一个名为“example.csv”的CSV文件写入到内存中,并使用csv.writer()函数将数据写入到该文件中:

import csv  
  
# 将数据存储到内存中  
data = [  
    ['Name', 'Age', 'City'],  
    ['John Doe', 30, 'New York'],  
    ['Jane Smith', 25, 'San Francisco'],  
    ['Bob Johnson', 40, 'Chicago']  
]  
  
# 创建一个csv.writer对象  
writer = csv.writer(open('example.csv', 'w', newline=''))  
  
# 写入数据到csv.writer对象中  
for row in data:  
    writer.writerow(row)

在上述代码中,我们首先定义了一个包含数据的二维列表data。然后,我们使用csv.writer()函数创建一个csv.writer对象,并将其绑定到打开的文件“example.csv”上。接下来,我们使用writerow()方法将每一行数据写入到csv.writer对象中。最后,我们使用close()方法关闭csv.writer对象和文件。

如果要将其他类型的数据写入到CSV文件中,可以使用csv.DictWriter()函数创建一个字典写入器对象。csv.DictWriter()函数接受三个参数:文件对象、字段名和引号字符。以下是一个示例代码,演示了如何使用csv.DictWriter()函数将字典数据写入到CSV文件中:

import csv  
  
# 定义字段名  
fields = ['Name', 'Age', 'City']  
  
# 定义数据字典  
data = [  
    {'Name': 'John Doe', 'Age': 30, 'City': 'New York'},  
    {'Name': 'Jane Smith', 'Age': 25, 'City': 'San Francisco'},  
    {'Name': 'Bob Johnson', 'Age': 40, 'City': 'Chicago'}  
]  
  
# 创建一个csv.DictWriter对象  
writer = csv.DictWriter(open('example.csv', 'w'), fieldnames=fields)  
  
# 写入数据到csv.DictWriter对象中  
writer.writeheader()  # 写入标题行  
for row in data:  
    writer.writerow(row)  # 写入数据行

四、处理大型CSV文件

如果需要处理大型CSV文件,我们可以使用pandas库,它提供了更高效的处理方式。pandas库中的read_csv()函数可以读取大型CSV文件,并将其转换为DataFrame对象,以便进行数据处理和分析。以下是一个示例代码,演示了如何使用pandas库处理大型CSV文件:

import pandas as pd  
  
# 读取大型CSV文件  
df = pd.read_csv('large_file.csv')  
  
# 对数据进行处理和分析  
# ...  
  
# 将结果写入新的CSV文件中  
df.to_csv('new_file.csv', index=False)

在上述代码中,我们首先使用pd.read_csv()函数读取名为“large_file.csv”的大型CSV文件,并将其存储在DataFrame对象df中。然后,我们可以对df对象进行数据处理和分析。最后,我们使用to_csv()方法将处理后的数据写入到新的CSV文件中。

五、总结

本文介绍了Python中读写CSV文件的方法。通过使用内置的csv模块或第三方库pandas,我们可以轻松地读取和写入CSV文件中的数据,并对数据进行处理和分析。使用这些技术,我们可以有效地处理各种类型的CSV文件,包括小型、大型以及包含特殊字符或格式的CSV文件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/218685.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

手机充电器市场分析:预计2028年将达到82亿美元

在5G时代飞速发展的今天,随着科技的进步、应用的发展以及人们对以智能手机、平板电脑、智能穿戴设备为代表的智能终端设备追求越来越高的品质和功能,智能终端设备产品的更新换代的速度越来越快,这也将给全球智能终端充储电产品市场带来更大的…

计算机基础知识64

ForeignKey属性 to:设置要关联的表 related_name: 反向操作时,使用的字段名,用于代替原反向查询时的’表名_set’ related_query_name:反向查询操作时,使用的连接前缀,用于替换表名 to_field:设置要关联的表…

【黑马甄选离线数仓day09_会员主题域开发_DWD和DWM层】

拉链表流程 1.从ODS层获取增量数据(上一天新增和更新的数据) 2.拿着DWD原始拉链表数据 left join 增量数据 ,修改原始拉链中历史数据的结束时间 3.拿着left join 的结果集 union all 增量数据 4.把最新的拉链数据优先保存到DWD对应的临时表中 5.使用insertselect 方式把临时表中…

8000元投影仪值得买吗?选择一步到位当贝X5 Ultra不用担心白天看不见

随着生活方式的变化,现在越来越多家用将家里的电视机换成屏幕更大的投影仪,投影仪似乎要逐渐取代电视机在家庭中的位置;然而近日在抖音刷到河南广播电视台民生频道的一个视频:河南郑州一小伙花了八千多买了极米投影仪,…

Scala 从入门到精通

Scala 从入门到精通 数据类型 pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http:…

LeetCode [中等]全排列(回溯算法)

46. 全排列 - 力扣&#xff08;LeetCode&#xff09; 回溯法 采用试错的思想&#xff0c;它尝试分步的去解决一个问题。在分步解决问题的过程中&#xff0c;当它通过尝试发现现有的分步答案不能得到有效的正确的解答的时候&#xff0c;它将取消上一步甚至是上几步的计算&…

怎么对文件加密?文件加密软件操作保姆式演示!

大家是不是遇到过这种情况&#xff0c;文件一个不小心就被别人轻易外发出去&#xff0c;并且还是特别重要的内容。在企业中这种现象已经非常常见啦。 今天就给友友们&#xff0c;分享一款神器&#xff0c;它可以让你点点鼠标&#xff0c;就对企业的重要文件进行加密。 1、获取…

学习php中使用composer下载安装firebase/php-jwt 以及调用方法

学习php中使用composer下载安装firebase/php-jwt 以及调用方法 1、安装firebase/php-jwt2、封装jwt类 1、安装firebase/php-jwt composer require firebase/php-jwt安装好以后出现以下文件: 2、封装jwt类 根据所使用的php框架&#xff0c;在指定目录创建 Token.php <?ph…

llama.cpp部署(windows)

一、下载源码和模型 下载源码和模型 # 下载源码 git clone https://github.com/ggerganov/llama.cpp.git# 下载llama-7b模型 git clone https://www.modelscope.cn/skyline2006/llama-7b.git查看cmake版本&#xff1a; D:\pyworkspace\llama_cpp\llama.cpp\build>cmake --…

Angular 进阶之四:SSR 应用场景与局限

应用场景 内容丰富&#xff0c;复杂交互的动态网页&#xff0c;对首屏加载有要求的项目&#xff0c;对 seo 有要求的项目&#xff08;因为服务端第一次渲染的时候&#xff0c;已经把关键字和标题渲染到响应的 html 中了&#xff0c;爬虫能够抓取到此静态内容&#xff0c;因此更…

修改python打包后的窗体图标、任务栏图标、exe图标

前言 我python开发的GUI界面(图形用户界面)一直是tkinter&#xff0c;打包exe一直是Pyinstaller。但是打包出来的exe图标、状态栏图标、窗体左上角图标一直是默认的羽毛&#xff0c;我想自定义。 效果 最后使用base64创建临时ico解决了该问题 步骤 创建icoToBase64.py&am…

如何使用 Oracle SQL Developer 连接 pgvector

如何使用 Oracle SQL Developer 连接 pgvector 1. 下载 postgresql 的 jdbc 驱动2. Oracle SQL Developer 配置第三方驱动3. Oracle SQL Developer 配置 postgres 连接 1. 下载 postgresql 的 jdbc 驱动 访问 https://jdbc.postgresql.org/download/&#xff0c;下载驱动&…

09.复刻ChatGPT,自我进化,AI多智能体

文章目录 复刻ChatGPT原因准备开整ALpacaVicuna GPT-4 EvaluationDolly 2.0其他合集Self-improve 自我进化表现形式法1&#xff1a;自我催眠法2&#xff1a;Agent交互法3&#xff1a;ReasonAct AI多智能体AI规划角色的一天加入亿点点细节&#xff08;外界刺激&#xff09;Refle…

STM32存储左右互搏 SPI总线读写FRAM MB85RS16

STM32存储左右互搏 I2C总线读写FRAM MB85RS16 在中低容量存储领域&#xff0c;除了FLASH的使用&#xff0c;&#xff0c;还有铁电存储器FRAM的使用&#xff0c;相对于FLASH&#xff0c;FRAM写操作时不需要预擦除&#xff0c;所以执行写操作时可以达到更高的速度&#xff0c;其…

【教程】苹果推送证书的创建和使用流程详解

摘要 本篇博客主要介绍了苹果推送证书的使用流程。首先&#xff0c;在苹果开发者中心创建推送证书&#xff0c;然后在应用程序中使用该证书进行消息推送。文章详细说明了创建推送证书的步骤&#xff0c;并提供了在应用程序中注册推送服务、发送推送消息以及处理推送消息的相关…

深入浅出理解kafka ---- 万字总结

1.Kafka简介 Kafka 本质上是一个 MQ&#xff08;Message Queue&#xff09;&#xff0c;使用消息队列的优点&#xff1a; 解耦&#xff1a;允许独立的扩展或修改队列两边的处理过程。可恢复性&#xff1a;即使一个处理消息的进程挂掉&#xff0c;加入队列中的消息仍然可以在系…

赛氪网荣膺地理标志语言服务教育与实践基地联盟理事会员单位

随着地理标志产品推介需求的持续扩大&#xff0c;知识产权保护和语言服务行业面临着新的挑战和机遇。在这个背景下&#xff0c;知识产权出版社指导下的地理标志语言服务教育与实践基地联盟应运而生&#xff0c;旨在推动地理标志产品的推广和知识产权保护。赛氪网作为项目运营方…

单行文本溢出,多行文本溢出的省略样式

单行文本溢出 效果&#xff1a; html <div>你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;你好呀&#xff01;</div> css: <style>div{width: 300p…

Python中的内省与反射机制及其应用场景

1. 概述 在计算机学中&#xff0c;反射式编程&#xff08;英语&#xff1a;reflective programming&#xff09;或反射&#xff08;英语&#xff1a;reflection&#xff09;&#xff0c;是指计算机程序在运行时&#xff08;runtime&#xff09;可以访问、检测和修改它本身状态或…

C++基础 -40- STL库之Vectors向量容器

Vectors 包含着一系列连续存储的元素,类似数组。 Vectors 定义格式&#xff08;需要调用头文件&#xff09; 赋值 遍历 全部代码段 #include "iostream" #include "vector" using namespace std;int main() {//定义vector<string> array1;//使…