当前位置: 首页 > news >正文

利用Python的csv(CSV)库读取csv文件并取出某个单元格的内容的学习过程

csv库在python3中是自带的。

利用它可以方便的进行csv文件内容的读取。

注意:要以gbk的编码形式打开,因为WPS的csv文件默认是gbk编码,而不是utf-8

01-读取表头并在打印每一行内容时一并输出表头

表头为第1行,现在要读取并打印出第2行的内容,并附加上表头信息的代码如下:

import csvfile_path = r'E:\Temp\test01.csv'with open(file_path, 'r', newline='', encoding='gbk') as file:# 创建CSV字典文件读取器reader = csv.DictReader(file)# 读取第二行的各列内容并打印second_row = next(reader)for column_title, value in second_row.items():print(f"{column_title}: {value}")

运行效果如下:
在这里插入图片描述
在这里插入图片描述

如果要读取第3行的内容,代码如下:

import csvfile_path = r'E:\Temp\test01.csv'with open(file_path, 'r', newline='', encoding='gbk') as file:# 创建CSV字典文件读取器reader = csv.DictReader(file)# 读取第三行的各列内容并打印second_row = next(reader)third_row = next(reader)for column_title, value in second_row.items():print(f"{column_title}: {value}")

运行效果如下:
在这里插入图片描述
在这里插入图片描述

02-涉及到的相关对象

02-01-DictReader对象:通过方法DictReader读取csv文件得到的DictReader对象

通过语句:reader = csv.DictReader(file)读取csv文件后,reader 是一个DictReader对象,其属性如下:
在这里插入图片描述
从中我们可以看出,在属性fieldnames中,存储了这个csv文件的表头。

另外,有个名叫line_num的存储了当前位于第几行【行数是从1开始算,不是从0开始算】,比如截图中的line_num的值为3,那么代表当前位于第3行。注意这个值是只读的,是不能修改的,它是基于当前的内存位置得出的。如果要改变它的值,我们只能通过类似于下面的语句去迭代增长内存位置,从而改变它的值:

current_row = next(reader)

或者:

for current_row in reader

这个值其实挺有用的,比如我可以设置我想读哪一行的内容,然后通过如上面的for循环去迭代DictReader对象,当这个值等于我设置的行数时,就可以去读取我想要的内容了。

02-02-每一行的内容实际上是一个字典对象

对于下面两句代码返回的对象:

    second_row = next(reader)third_row = next(reader)

看下面的这两张截图就知道了:
在这里插入图片描述

在这里插入图片描述
所以就不多说什么了。

03-读取表头并打印出指定行的内容的代码

假如要读第1000行的内容,咱们不可能去写999条语句second_row = next(reader)呀,根据02-01中对DictReader对象的属性line_num的分析,我们可以像下面这样写代码:

import csvfile_path = r'E:\Temp\test01.csv'with open(file_path, 'r', newline='', encoding='gbk') as file:# 创建CSV字典文件读取器reader = csv.DictReader(file)# 读取到第1000行target_row_number = 1000for row in reader:if reader.line_num == target_row_number:# 在这里你可以处理目标行的内容for column_title, value in row.items():print(f"{column_title}: {value}")break  # 退出循环,因为我们已经读取到了目标行

我们把上面的 target_row_number的值换成2,运行效果如下:
在这里插入图片描述

在这里插入图片描述

我们把上面的 target_row_number的值换成3,运行效果如下:
在这里插入图片描述

在这里插入图片描述
从上面的结果来看,实现了我们的需求。

http://www.lryc.cn/news/281474.html

相关文章:

  • Http三种常见状态码的区别(401、403、500)
  • 分布式锁实现用户锁
  • R语言【paleobioDB】——pbdb_subtaxa():统计指定类群下的子类群数量
  • 3.4 在开发中使用设计模式
  • docker搭建SSH镜像、systemctl镜像、nginx镜像、tomcat镜像
  • [linux] git clone一个repo,包括它的子模块submodule
  • K8S中使用helm安装MinIO
  • 寒假刷题第六天
  • 深度学习笔记(七)——基于Iris/MNIST数据集构建基础的分类网络算法实战
  • Windows启动MongoDB服务报错(错误 1053:服务没有及时响应启动或控制请求)
  • Android Framework 常见解决方案(25-2)定制CPUSET解决方案-system修改及编译部分调整
  • OpenAI推出GPT商店和ChatGPT Team服务
  • 3D建模素材分层渲染怎么操作?
  • SAICP(模拟退火迭代最近点)的实现
  • FineBI实战项目一(23):订单商品分类词云图分析开发
  • DOS命令
  • 【Python】torch中的.detach()函数详解和示例
  • 二级域名分发系统源码 对接易支付php源码 全开源
  • 二分查找与搜索树的高频问题(算法村第九关白银挑战)
  • Python爬虫快速入门
  • 部署MinIO
  • RK3566环境搭建
  • 精确掌控并发:滑动时间窗口算法在分布式环境下并发流量控制的设计与实现
  • Python展示 RGB立方体的二维切面视图
  • 03 顺序表
  • 2023年全球软件开发大会(QCon北京站2023)9月:核心内容与学习收获(附大会核心PPT下载)
  • ChatGPT 和 文心一言 的优缺点及需求和使用场景
  • 架构师之超时未支付的订单进行取消操作的几种解决方案
  • 【容器固化】 OS技术之OpenStack容器固化的实现原理及操作
  • 设置 SSH 通过密钥登录