【12】将txt文件数据存储到csv文件(使用空格划分)

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'])

如果你觉得这篇文章对你有所启发的话,期待你的点赞、收藏和打赏,对我创作的支持!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用Java文件读写操作和字符串处理操作来将txt文件数据转入到csv文件。 以下是一个简单的示例代码,假设txt文件的每一行数据以逗号分隔,每行数据都有相同数量的字段: ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; public class TxtToCsvConverter { public static void main(String[] args) { String inputFilePath = "input.txt"; String outputFilePath = "output.csv"; try (BufferedReader reader = new BufferedReader(new FileReader(inputFilePath)); FileWriter writer = new FileWriter(outputFilePath)) { String line; while ((line = reader.readLine()) != null) { String[] fields = line.split(","); for (int i = 0; i < fields.length; i++) { writer.append(fields[i]); if (i < fields.length - 1) { writer.append(","); } } writer.append("\n"); } } catch (IOException e) { e.printStackTrace(); } } } ``` 在上面代码,我们使用了Java的BufferedReader和FileReader来读取txt文件数据使用FileWriter来写入csv文件数据。在读取每一行数据时,我们使用了String类的split方法将每一行数据按逗号分隔成一个字符串数组,然后使用for循环将数组的每个字段按顺序写入csv文件,并在每行数据的末尾添加一个换行符。 使用以上代码,你可以将一个名为“input.txt”的txt文件数据转入到一个名为“output.csv”的csv文件。你只需将inputFilePath和outputFilePath变量的值改为你自己的文件路径即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_x_w

你的肯定是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值