Python实现数据保存为PSV文件(先创建CSV,转换成PSV)

 CSV格式文件:分隔符 ',' comma逗号

PSV格式文件:分隔符'|',管道文件pipe-delimited text files

TSV 格式文件:分隔符' '  tab空格

步骤:

1、先创建CSV文件,保存数据,保存数据时定义分隔符为管道分隔符

2、批量修改CSV的后缀为PSV

注意的问题是:数据保存时可能出现未换行保存,为此在创建CSV文件时要索引数据逐行循环写入

代码实现

#创建CSV文件,并保存数据  
import csv
def create_csv(path,data):
    with open(path,'w', newline='') as f:
        csv_write = csv.writer(f, delimiter='|')
        for i in range(len(data)):#使用循环写入行实现换行,关键
            csv_head = data[i,:]#针对一行多列情况
            csv_write.writerow(csv_head)
def create_csv(path, data):
    with open(path, 'w', newline='') as f:
        csv_write = csv.writer(f, delimiter='|')
        #列表只有一列
        csv_head = data
        csv_write.writerow(csv_head)

 

 ### 批量修改文件后缀名(自定义目录)
import os
import sys
def revised_path_name(path,suffix_pre,suffix_later):
   
    path0=path
    path1=path0+'/' #等价于 path1=path0+'\\'
    sys.path.append(path1)
    # print(sys.path)
    
    # 列出当前目录下所有的文件
    files = os.listdir(path0)
    
    # files = os.listdir('.')
    
    print('files',files)
    
    for filename in files:
    	portion = os.path.splitext(filename)#该语句的作用是将文件名拆分为文件名和后缀
    	# 如果后缀是.txt
    	if portion[1] == suffix_pre:  
    		# 重新组合文件名和后缀名
    		
    		newname = portion[0] + suffix_later 
    		filenamedir=path1 +filename
    		newnamedir=path1+newname
    		
    		# os.rename(filename,newname)
    		os.rename(filenamedir,newnamedir)

执行程序:

# 创建CSV 文件保存预测结果      
path="D:/Python Example/test/test5.csv"    
create_csv(path,predict_y)
#covert_csv_to_psv()
revised_path_name("D:/Python Example/test/",".csv",".psv" )

参考资料

1、python 读写csv文件(创建,追加,覆盖) python 读写csv文件(创建,追加,覆盖)_lwgkzl的博客-CSDN博客_python怎么创建csv文件 

    该方法出现的问题是对于列表数据,并没有换行保存

2、python文件操作3--批量修改文件后缀名 python文件操作3--批量修改文件后缀名_rosefunR的博客-CSDN博客_python 修改文件后缀

   对任意目录下批量修改进行接口修改

3、Convert csv file to pipe delimited file in Python  https://stackoverflow.com/questions/27551386/convert-csv-file-to-pipe-delimited-file-in-python

4、Python的 CSV File Reading and Writing 14.1. csv — CSV File Reading and Writing — Python 3.3.7 documentation

5、Text Files: CSV, TSV, PSV Text Files: CSV, TSV, PSV - Apache Drill

6、写为其它格式Python 将列表数据写入文件(txt, csv, excel)  Python 将列表数据写入文件(txt, csv, excel)_TWLS的博客-CSDN博客_python将列表写入excel

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 要用Python实现接收到的串口数据保存CSV文件,可以按照以下步骤进行: 1. 导入所需的模块,包括serial和csv模块。可以使用以下命令导入: ```python import serial import csv ``` 2. 设置串口参数,包括串口号、波特率、数据位、停止位和校验位等。可以使用以下命令设置: ```python ser = serial.Serial('COM1', 9600, 8, 'N', 1) ``` 其中,'COM1'是串口号,9600是波特率,8是数据位,'N'是校验位,1是停止位。 3. 读取串口数据保存CSV文件。可以使用以下命令: ```python with open('data.csv', 'w', newline='') as csvfile: writer = csv.writer(csvfile) while True: data = ser.readline().decode().strip() if data: writer.writerow([data]) ``` 其中,'data.csv'是保存CSV文件文件名,'w'表示以写入模式打开文件,'newline='表示不使用换行符,使用系统默认的换行符。然后,使用csv.writer()函数创建一个writer对象,用于写入CSV文件。在一个无限循环中,使用ser.readline()函数读取串口数据,并使用strip()函数去掉字符串前后的空格和换行符。如果读取到数据,则使用writer.writerow()函数将数据写入CSV文件。 4. 最后,关闭串口和CSV文件。可以使用以下命令: ```python ser.close() csvfile.close() ``` 以上就是用Python实现接收到的串口数据保存CSV文件的步骤。 ### 回答2: 在Python中,要实现接收到的串口数据保存CSV文件,可以按照以下步骤进行: 1. 首,需要安装pySerial库,它是Python的一个串口通信库,可以方便地与串口进行通信。可以使用以下命令进行安装:pip install pyserial 2. 导入所需的模块:import serial,import csv,import time 3. 设置串口的端口号、波特率等参数:port = 'COM1',baudrate = 9600 4. 打开串口:ser = serial.Serial(port, baudrate) 5. 创建一个CSV文件,用于保存接收到的数据csv_file = open('data.csv', 'w', newline='') 6. 创建一个CSV写入器:writer = csv.writer(csv_file) 7. 可选的步骤:如果需要添加CSV文件的表头,可以使用writer.writerow()方法来添加:writer.writerow(['数据1', '数据2', ...]) 8. 循环读取串口数据并写入CSV文件,直到停止条件满足:while True: data = ser.readline().decode('utf-8').strip() writer.writerow(data.split(',')) # 根据实际的数据格式进行分割 and 具体的处理逻辑 if data == '停止条件': break 9. 关闭串口和CSV文件:ser.close(),csv_file.close() 以上是一个简单的实现串口数据保存CSV文件的示例代码,注意其中的一些细节需要根据实际需求进行调整。 ### 回答3: 要实现将接收到的串口数据保存CSV文件,可以使用Python的`serial`库来读取串口数据,使用`csv`库来操作CSV文件。 首,需要安装Python的`serial`与`csv`库。可以使用以下命令安装库: ``` pip install pyserial ``` ``` pip install csv ``` 以下是一个实现的示例代码: ```python import serial import csv # 打开串口 ser = serial.Serial('COM1', 9600) # 串口号与波特率根据实际情况更改 # 创建CSV文件 csv_file = open('data.csv', 'w', newline='') csv_writer = csv.writer(csv_file) # 读取接收到的串口数据并写入CSV文件 while True: data = ser.readline().decode().strip() # 读取并解码串口数据 csv_writer.writerow([data]) # 写入CSV文件 # 可以添加自定义的退出条件 if data == 'exit': break # 关闭串口与CSV文件 ser.close() csv_file.close() ``` 以上代码通过`serial`库打开串口,并通过`csv`库创建了一个CSV文件。然后,使用`serial.Serial`方法指定串口号与波特率,使用`serial.readline`方法读取串口数据,并使用`decode`方法进行解码和去除首尾空格。接着,利用`csv.writer`方法创建了一个写入CSV文件的对象,并使用`csv_writer.writerow`方法将数据写入CSV文件中。最后,在某种条件下退出循环,并关闭串口与CSV文件。 代码中需要根据实际情况修改串口号、波特率以及CSV文件名。同时,可以根据需求添加读取数据的格式和条件。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

heda3

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值