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

76 Python写入csv文件时出现空行_newline参数解决

76 Python写入csv文件时出现空行_newline参数解决

文章目录

  • 76 Python写入csv文件时出现空行_newline参数解决
    • 1. 准备工作
    • 2. with open 语句没有newline参数
    • 3. with open 语句有newline参数
    • 4. 总结

1. 准备工作

  1. 在电脑D盘新建一个【76】文件夹。

  2. 用VScode编辑器打开【76】文件夹。

  3. 在【76】文件夹里新建一个76.py文件。

  4. 大家在76.py文件里编写代码。

2. with open 语句没有newline参数

# 导入os 模块,用于创建文件目录
import os
# 导入 csv 模块,用于操作CSV文件
import csv# mkdir作用是创建目录
# 相对路径
os.mkdir("各班级成绩")# 用字典存储要写入CSV文件的信息
dict1 = {'姓名': '刘一', '成绩': '100'}
dict2 = {'姓名': '陈二', '成绩': '90'}# 设置文件的表头,即列名
header = ['姓名', '成绩']# 文件的相对路径
file_path = r'各班级成绩\1班成绩单.csv'# 以自动关闭文件的方式创建文件对象
with open(file_path, 'w', encoding='utf-8') as f:# 实例化类 DictWriter(),得到 DictWriter 对象dw = csv.DictWriter(f, fieldnames=header)# 写入文件的表头dw.writeheader()# 写入内容,每次写入一行dw.writerow(dict1)dw.writerow(dict2)

newline [n’ju:laɪn]:换行。

运行上述代码,我们在【76】文件夹里新建了一个【各班级成绩】文件夹。

在【各班级成绩】文件夹里新建了一个【一班成绩单.csv】文件。

并在【一班成绩单.csv】文件写入了2个字典里的内容。

打开【一班成绩单.csv】文件,我们发现CSV文件行与行之间多了一行空行。

在这里插入图片描述

这是因为newline参数在作妖。

在open或with open语句中,参数 newline 表示用于区分换行符,只对文本模式有效,可以取的值有None\n\r

意思就是在open或with open语句中,如果没有添加newline参数,那csv文件行与行之间会默认有个空行。

如果你不需要这个空行,那你可以在open或with open语句中添加newline参数

参数 newline可以取的值有None\n\r

3. with open 语句有newline参数

# 导入 csv 模块,用于操作CSV文件
import csv# 用字典存储要写入CSV文件的信息
dict1 = {'姓名': '刘一', '成绩': '100'}
dict2 = {'姓名': '陈二', '成绩': '90'}# 设置文件的表头,即列名
header = ['姓名', '成绩']# 文件的相对路径
file_path = r'各班级成绩\2班成绩单.csv'# 以自动关闭文件的方式创建文件对象
with open(file_path, 'w', encoding='utf-8', newline="\r") as f:# 实例化类 DictWriter(),得到 DictWriter 对象dw = csv.DictWriter(f, fieldnames=header)# 写入文件的表头dw.writeheader()# 写入内容,每次写入一行dw.writerow(dict1)dw.writerow(dict2)

运行上面的代码,打开得到的【2班成绩单.csv】文件,如下所示:

在这里插入图片描述

此时输出的结果就没有空行。

这是因为我在with open 语句中增加了newline=""参数。

# 以自动关闭文件的方式创建文件对象
with open(file_path, 'w', encoding='utf-8', newline="") as f:

【温馨提示】

上述两段代码是有区别的。

  1. 第2段代码我删除了os相关的语句(下面的代码被删除):
# 导入os 模块,用于创建文件目录
import os# mkdir作用是创建目录
# 相对路径
os.mkdir("各班级成绩")

因为【各班级成绩】文件夹已经存在,如果我们在创建该目录,程序会报错。

  1. 我修改了下面的路径变量:

第一段代码的路径变量:

# 文件的相对路径
file_path = r'各班级成绩\1班成绩单.csv'

第二段代码的路径变量:

# 文件的相对路径
file_path = r'各班级成绩\2班成绩单.csv'

将【1班成绩单.csv】修改成了【2班成绩单.csv】

4. 总结

newline=""参数输出的结果没有空行。

没有newline=""参数输出的结果有空行。

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

相关文章:

  • 高等数学——定积分和不定积分
  • imx6 usb增强信号强度
  • 深入理解性能压测工具原理
  • Java的概述和运行方式
  • 【C语言】每日刷题 —— 牛客
  • JavaEE课程实践-Servlet的部署(tomcat服务器)
  • Java 中的拆箱和装箱
  • 从0开始自制解释器——实现多位整数的加减法计算器
  • (12)C#传智:File类,泛型,字典,FileStream,StreamReader,多态
  • Dubbo的服务暴漏与服务发现源码详解
  • Python 的IDE——PyCharm
  • 01 C语言使用链表实现队列(Queue、FIFO)模块
  • 2.2操作系统-进程管理:前趋图、前趋图与PV操作
  • 凤凰游攻略
  • Nginx 高可用方案
  • Linux基本指令
  • Linux系统基础命令(二)
  • 【C++】C++11——简介|列表初始|简化声明|nullptr与范围for|STL中的变化
  • Python -- 函数
  • Pytorch中utils.data 与torchvision简介
  • 学习 Python 之 Pygame 开发魂斗罗(十)
  • Keepalive+LVS群集部署
  • 数组、指针总结【面试题】
  • 七色电子标签
  • 大数据是什么?发展前景怎么样
  • MYSQL必知必会 | 查询相关
  • Java学习环境一站说明(保姆级详细教学)
  • 05-Oracle中的对象(视图,索引,同义词,系列)
  • 如何通过websoket实现即时通讯+断线重连?
  • 爽,我终于掌握了selenium图片滑块验证码