0 前言
在跑程序的时候,有一个需求就是将txt文件中的数据导入到csv文件,并将txt文件中的数据按照空格进行划分为csv文件中的不同行。
1 完整代码
import csv
csvFile = open(r'C:/Users/27801/Desktop/results.csv', 'w', newline='', encoding='utf-8')
writer = csv.writer(csvFile)
csvRow = []
f = open(r'C:/Users/27801/Desktop/results.txt', 'r', encoding='utf-8')
for line in f:
csvRow = line.split()
writer.writerow(csvRow)
f.close()
csvFile.close()
2 代码解析
csvFile = open(r'C:/Users/27801/Desktop/results.csv', 'w', newline='', encoding='utf-8')
首先是用来以写入(‘w’)模式打开一个名为 ‘results.csv’ 的文件。同时指定了编码为 UTF-8。参数 newline=‘’ 是为了避免在写入 CSV 文件时把空格也当做为具体内容写入;newline参数的具体表现,读者可以自行将该参数删除和添加的方式来对比效果。
writer = csv.writer(csvFile)
创建一个 CSV writer 对象,以便将数据写入到 CSV 文件中。
f = open(r'C:/Users/27801/Desktop/results.txt', 'r', encoding='utf-8')
for line in f:
csvRow = line.split()
writer.writerow(csvRow)
和前面打开文件的区别在于以只读(‘r’)模式打开results.txt文件;循环读取文件的每一行数据(for循环),对于每一行的数据按空格分割(split)为一个列表;然后将一个个列表逐行地(‘writerow’)写入csv文件中。
f.close()
csvFile.close()
操作完成,关闭打开的两个文件。
3 拓展延伸
下面有两个简单的例子,供读者更好把握逐行写入数据的操作。
import csv
# 打开一个 CSV 文件进行写操作
with open('example.csv', 'w', newline='') as csvfile:
csvwriter = csv.writer(csvfile)
# 使用 writerow() 方法写入一行数据
csvwriter.writerow('Name Age City'.split())
csvwriter.writerow('Alice 25 NewYork'.split())
csvwriter.writerow('Bob 30 SanFrancisco'.split())
import csv
# 打开一个 CSV 文件进行写操作
with open('example.csv', 'w', newline='') as csvfile:
csvwriter = csv.writer(csvfile)
# 使用 writerow() 方法写入一行数据
csvwriter.writerow(['Name', 'Age', 'City'])
csvwriter.writerow(['Alice', 25, 'New York'])
csvwriter.writerow(['Bob', 30, 'San Francisco'])
如果你觉得这篇文章对你有所启发的话,期待你的点赞、收藏和打赏,对我创作的支持!!!