十分钟教会你用Python处理CSV文件

作者:程序员仓库 时间:2022-02-05 02:24:12 

前言

在前几年,如果你和嵌入式开发人员推荐Python,大概会是这样一种场景:

A:”诶,老王,你看Python开发这么方便,以后会不会用到嵌入式设备?“

B:“别做梦了,那玩意儿速度贼慢,肯定满足不了性能要求…”

但近几年,随着半导体行业的迅猛发展,嵌入式处理器的性能有了很大幅度的提高。与此同时,Python语言本身也在不断优化。因此,在嵌入式领域引入Python已经成为了必然趋势。

今天,作者就来总结一下使用Python处理物联网行业中一种常见的文件格式:csv文件。

Python库:csv

Python中集成了专用于处理csv文件的库,名为:csv。

csv 库中有4个常用的对象:

  • csv.reader:以列表的形式返回读取的数据。

  • csv.writer:以列表的形式写入数据。

  • csv.DictReader:以字典的形式返回读取的数据。

  • csv.DictWriter:以字典的形式写入数据。

读取csv文件

假设现在要读取的csv文件内容如下:

十分钟教会你用Python处理CSV文件

可以看到,该文件的第一行表明数据类型,我们暂且称之为header。从第2行开始,保存的是设备采集到的数据。

使用csv.reader读取数据

# 导入 csv 库
import csv

# 以读方式打开文件
with open("data.csv", mode="r", encoding="utf-8-sig") as f:

# 基于打开的文件,创建csv.reader实例
   reader = csv.reader(f)

# 获取第一行的header
   # header[0] = "设备编号"
   # header[1] = "温度"
   # header[2] = "湿度"
   # header[3] = "转速"
   header = next(reader)

# 逐行获取数据,并输出
   for row in reader:
       print("{}{}: {}={}, {}={}, {}={}".format(header[0], row[0],
                                                header[1], row[1],
                                                header[2], row[2],
                                                header[3], row[3]))

程序运行结果如下:

设备编号0: 温度=31, 湿度=20, 转速=1000
设备编号1: 温度=30, 湿度=22, 转速=998
设备编号2: 温度=32, 湿度=23, 转速=1005

使用csv.DictReader读取数据

# 导入 csv 库
import csv

# 打开文件
with open("data.csv", encoding="utf-8-sig", mode="r") as f:

# 基于打开的文件,创建csv.DictReader实例
   reader = csv.DictReader(f)

# 输出信息
   for row in reader:
       print("设备编号{}: 温度={}, 湿度={}, 转速={}".format(row["设备编号"],
                                                  row["温度"],
                                                  row["湿度"],
                                                  row["转速"]))

程序运行结果如下:

设备编号0: 温度=31, 湿度=20, 转速=1000
设备编号1: 温度=30, 湿度=22, 转速=998
设备编号2: 温度=32, 湿度=23, 转速=1005

写入csv文件

假设我们现在要创建一个csv文件,将数据保存为如下形式:

十分钟教会你用Python处理CSV文件

使用csv.writer写入数据

# 导入 csv 库
import csv

# 创建列表,保存header内容
header_list = ["设备编号", "温度", "湿度", "转速"]

# 创建列表,保存数据
data_list = [
   [0, 31, 20, 1000],
   [1, 30, 22, 998],
   [2, 32, 33, 1005]
]

# 以写方式打开文件。注意添加 newline="",否则会在两行数据之间都插入一行空白。
with open("new_data.csv", mode="w", encoding="utf-8-sig", newline="") as f:

# 基于打开的文件,创建 csv.writer 实例
   writer = csv.writer(f)

# 写入 header。
   # writerow() 一次只能写入一行。
   writer.writerow(header_list)

# 写入数据。
   # writerows() 一次写入多行。
   writer.writerows(data_list)

使用csv.DictWriter写入数据

# 导入 csv 库
import csv

# 创建 header 列表
header_list = ["设备编号", "温度", "湿度", "转速"]

# 创建数据列表,列表的每个元素都是字典
data_list = [
   {"设备编号": "0", "温度": 31, "湿度": 20, "转速": 1000},
   {"设备编号": "1", "温度": 30, "湿度": 22, "转速": 998},
   {"设备编号": "2", "温度": 32, "湿度": 23, "转速": 1005},
]

# 以写方式打开文件。注意添加 newline="",否则会在两行数据之间都插入一行空白。
with open("new_data.csv", mode="w", encoding="utf-8-sig", newline="") as f:

# 基于打开的文件,创建 csv.DictWriter 实例,将 header 列表作为参数传入。
   writer = csv.DictWriter(f, header_list)

# 写入 header
   writer.writeheader()

# 写入数据
   writer.writerows(data_list)

关于写入,需要注意:

  • 在打开文件时,需要添加newline = ""。否则,会在每2行有效内容之间添加一行空白。

  • 如果要保存的内容有中文,而且之后需要用Excel打开文件,那么需要选用utf-8-sig编码。如果使用utf-8编码,会导致使用Excel查看文件时中文乱码。

总结 

来源:https://blog.csdn.net/bryanwang_3099/article/details/119731390

标签:python,csv,文件
0
投稿

猜你喜欢

  • python教程十行代码教你语音转文字QQ微信聊天

    2024-01-03 09:06:54
  • 如何利用python实现列表嵌套字典取值

    2023-07-08 02:16:50
  • 边框样式的写法总结

    2009-01-18 13:00:00
  • python 实现数组list 添加、修改、删除的方法

    2021-10-21 16:27:34
  • python3去掉string中的标点符号方法

    2021-06-27 01:29:45
  • 一篇文章搞懂Python Unittest测试方法的执行顺序

    2023-11-01 09:38:01
  • Python实现配置文件备份的方法

    2021-06-11 01:39:03
  • python操作excel之openpyxl模块读写xlsx格式使用方法详解

    2021-01-16 23:17:50
  • python tkinter库实现气泡屏保和锁屏

    2021-09-17 22:37:57
  • 修改mysql密码与忘记mysql密码的处理方法

    2024-01-23 21:53:48
  • Apache2.4.x版wampserver本地php服务器如何让外网访问及启用.htaccess

    2023-11-04 09:27:00
  • 在JavaScript中调用Java类和接口的方法

    2024-04-10 10:42:49
  • 基于Django的乐观锁与悲观锁解决订单并发问题详解

    2021-07-14 19:42:08
  • python利用xpath爬取网上数据并存储到django模型中

    2022-01-19 03:46:51
  • Python编程图形库之Pillow使用方法讲解

    2022-04-07 06:10:57
  • SQL数据查询之DQL语言介绍

    2024-01-26 11:04:25
  • Python字典使用技巧详解

    2021-09-07 23:54:25
  • IE Cookie文件格式说明

    2023-03-13 17:17:22
  • Python 图片视频模糊化实现案例

    2023-05-28 11:50:52
  • 互联网产品设计师自我介绍

    2009-04-16 12:45:00
  • asp之家 网络编程 m.aspxhome.com