文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

【Python】Python读取CSV文件

2023-09-12 16:04

关注

CSV文件是一种常见的数据存储格式,很多人在日常工作中需要使用Python处理CSV文件。Python提供了多种方法来读取CSV文件,包括使用标准库、第三方库和内置函数。本文将介绍多种Python读取CSV文件的方法。

使用Python内置csv库读取CSV文件

Python标准库中的csv模块提供了方便的读取和写入CSV文件的方法。下面是一个示例代码:

import csvwith open('file.csv', 'r', encoding='utf-8') as csvfile:    reader = csv.reader(csvfile)    for row in reader:        print(row)

在上面的代码中,我们打开file.csv文件并使用csv.reader()函数读取文件。这个函数返回一个迭代器对象,我们可以使用for循环遍历每一行,并打印出来。需要注意的是,open()函数的encoding参数是必须的,否则可能会出现编码问题。

使用pandas库读取CSV文件

除了使用Python内置的csv模块,我们还可以使用pandas库来读取CSV文件。pandas是一个强大的数据处理库,可以轻松地处理和分析大型数据集。下面是一个示例代码:

import pandas as pddf = pd.read_csv('file.csv')print(df)

在上面的代码中,我们使用pd.read_csv()函数读取文件,并将其赋值给一个pandas DataFrame对象。然后,我们使用print()函数打印出整个DataFrame,它将显示整个CSV文件的内容。需要注意的是,pandas会自动检测分隔符和引号。

使用numpy库读取CSV文件

numpy是一个常用的科学计算库,它也提供了读取CSV文件的方法。下面是一个示例代码:

import numpy as npdata = np.genfromtxt('file.csv', delimiter=',', dtype=None, encoding='utf-8')print(data)

在上面的代码中,我们使用np.genfromtxt()函数读取文件,并将其赋值给一个numpy数组。这个函数可以自动识别分隔符和缺失值,并返回一个二维数组。需要注意的是,delimiter参数是必须的,否则函数将无法解析文件。

使用csvkit库读取CSV文件

csvkit是一个专门用于处理CSV文件的第三方库,它提供了多种方法来读取和处理CSV文件。下面是一个示例代码:

from csvkit import CSVKitReaderwith open('file.csv', 'r', encoding='utf-8') as csvfile:    reader = CSVKitReader(csvfile)    for row in reader:        print(row)

在上面的代码中,我们使用CSVKitReader()函数读取文件,并将其赋值给一个迭代器对象。这个函数可以自动识别分隔符和引号,并返回一个迭代器对象。需要注意的是,这个库需要单独安装。

使用pypyodbc库读取CSV文件

pypyodbc是一个用于连接和操作数据库的Python库,它也可以用来读取CSV文件。下面是一个示例代码:

import pypyodbcconn = pypyodbc.connect('Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=file.csv;')cur = conn.cursor()cur.execute('SELECT * FROM [Sheet1$]')for row in cur.fetchall():    print(row)

在上面的代码中,我们使用pypyodbc.connect()函数连接CSV文件,并使用SQL语句读取文件。需要注意的是,这个库需要单独安装,并且需要安装对应的ODBC驱动。

总结

本文介绍了多种方法来读取CSV文件,包括使用Python内置csv库、pandas库、numpy库、csvkit库和pypyodbc库。根据实际需求选择适合自己的方法。使用Python处理CSV文件,可以大大提高工作效率。

来源地址:https://blog.csdn.net/achen0511/article/details/130841304

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯