Python — 获取电脑串口数据并保存到txt文件

打开设备管理器,双击端口设备,点击端口设置,这里面的参数需要与下面代码中的参数保持一致。

版本一

import serial
import time

serialport = serial.Serial()
serialport.port = 'COM3'
serialport.baudrate = 115200
serialport.bytesize = 8
serialport.parity = serial.PARITY_NONE
serialport.stopbits = 1
serialport.timeout = 0.001
serialport.close()
if not serialport.is_open:
	serialport.open()
time.sleep(0.05) #时间设置参考串口传输速率
num = serialport.inWaiting()
while num == 0:
	time.sleep(0.05) #时间设置参考串口传输速率
	num = serialport.inWaiting()
if num > 0:
	data = serialport.read(num)
	# bytes转str
	print(str(data, 'UTF-8'))

注意事项:

1、设置匹配的波特率;

2、设置对应的串口号;

版本二

以下是一段Python代码,可以读取 Windows 电脑上串口的数据并将其保存到一个文本文件中:

import serial

# 串口配置
port = "COM1"  # 更改为你要读取的串口号
baud_rate = 115200  # 波特率,根据实际情况进行调整

# 打开串口
ser = serial.Serial(port, baud_rate)

# 打开文件
file_path = "data.txt"  # 更改为保存数据的文件路径
file = open(file_path, "w")

# 读取和保存数据
while True:
    if ser.in_waiting > 0:
        data = ser.readline().decode().strip()  # 读取并解码数据
        file.write(data + "\n")  # 写入文件
        file.flush()  # 刷新文件缓冲区
        print(data)  # 可选,打印读取到的数据

# 关闭文件和串口
file.close()
ser.close()

请注意,上述代码中的串口号和波特率需要根据你实际连接的设备进行修改。同时,代码中使用了一个无限循环来实时读取串口数据,你可以根据需要进行适当的修改。此外,如果需要在保存数据时进行其他处理,你可以根据具体需求进行相应的更改。

版本三、读取二进制数据流

import serial

# 设置串口参数
ser = serial.Serial('COM1', 9600, timeout=1)  # 根据实际情况修改串口名称和波特率

while True:
    # 读取串口数据
    data = ser.read()

    if data:
        # 将字节数据转换为字符串并打印
        print(data.decode('utf-8'))  # 根据实际使用的编码进行解码

版本4  实现rtcm32数据串口接受保存:

import datetime
import time

import serial
import os

from FileUtil import FileUtil

port = '/dev/ttyUSBnet'
btl = 115200
current_path = os.path.dirname(os.path.abspath(__file__))
current_time = "B" + datetime.datetime.now().strftime('%Y_%m_%d_%H_%M_%S') + ".rtcm"
fileutil = FileUtil(path=current_path, filename=current_time)
ser = serial.Serial(port, btl)
print(ser)

time_stamp = time.time()
cnt = 0
while True:
    if ser.in_waiting:
        data = ser.read()
        fileutil.writeByte(data)
        cnt = cnt + 1
        if cnt % 100 == 0:
            print(end=f'\r{"time :" +str(time.time()-time_stamp)}')
import os.path


class FileUtil:
    @staticmethod
    def strSplit(datas, sep):
        """
        :param datas: 一维数据
        :param sep: 分隔符
        :return: 二维数组
        """
        res = []
        for data in datas:
            res.append(str(data).split(sep))
        return res

    def __init__(self, path: str, filename: str):
        if not path.endswith("/"):
            path = path.__add__("/")
        print("写入文件目录" + path + filename)
        # 目录不存在则创建目录
        if not os.path.exists(path):
            os.makedirs(path)
        self.filename = path + filename

    def write(self, content):
        if not os.path.exists(self.filename):
            with open(self.filename, "w") as f:
                f.write(content)
        else:
            with open(self.filename, "a") as f:
                f.write(content)

    def writeByte(self, content):
        with open(self.filename, "ab") as f:
            f.write(content)

### 回答1: 可以使用Python读取Arduino串口数据将其存储到Excel表格中。可以使用Python的pySerial模块来读取串口数据使用Python的openpyxl模块将数据写入Excel表格。 ### 回答2: 要用Python读取Arduino串口数据存储到Excel表格,需要先安装pyserial和openpyxl这两个库。 首先,导入所需的库: ```python import serial import openpyxl ``` 然后,创建串口对象连接Arduino: ```python ser = serial.Serial('COM1', 9600) # 根据实际情况修改端口和波特率 ``` 接下来,创建一个Excel工作簿对象选择或新建一个工作表: ```python wb = openpyxl.Workbook() sheet = wb.active ``` 然后,设置表头: ```python sheet.cell(row=1, column=1).value = "时间" sheet.cell(row=1, column=2).value = "数据" ``` 接下来,通过循环不断读取串口数据将其写入Excel表格中的新行: ```python row = 2 # 从第二行开始写入数据 while True: data = ser.readline().strip().decode('utf-8') # 读取串口数据去除空白字符 if data: # 如果读取到有效数据 sheet.cell(row=row, column=1).value = datetime.now().strftime("%H:%M:%S") # 获取当前时间写入第一列 sheet.cell(row=row, column=2).value = float(data) # 将读取到的数据转为浮点数,写入第二列 row += 1 # 行号加1,准备写入下一行 ``` 最后,保存Excel文件: ```python wb.save("data.xlsx") ``` 通过以上步骤,就可以使用Python读取Arduino串口数据存储到Excel表格中。 ### 回答3: 要使用Python读取Arduino串口数据存储到Excel表格,您可以按照以下步骤进行操作。 1. 首先,确保已经安装了Python的pySerial库和pandas库。可以使用pip命令来安装它们。 2. 打开Arduino开发环境,编写代码将要传输的数据通过串口发送到电脑上。 3. 在Python中,导入必要的库: ```python import serial import pandas as pd ``` 4. 设置串口的参数,包括端口号、波特率等: ```python port = 'COM1' # 串口号,根据实际情况修改 baudrate = 9600 # 波特率,根据实际情况修改 ``` 5. 创建一个串口对象,打开串口: ```python ser = serial.Serial(port, baudrate) ``` 6. 创建一个空的DataFrame用于存储数据: ```python data = pd.DataFrame(columns=['Time', 'Data']) # 根据实际情况修改列名 ``` 7. 开始读取串口数据数据添加到DataFrame中: ```python while True: line = ser.readline().decode('utf-8').rstrip() # 每次读取一行数据移除末尾的换行符和空格 data = data.append({'Time': pd.Timestamp.now(), 'Data': line}, ignore_index=True) # 添加数据到DataFrame中 ``` 8. 当需要停止读取数据时,可以使用Ctrl+C来中断程序运行。 9. 最后,将DataFrame中的数据保存到Excel表格中: ```python data.to_excel('data.xlsx', index=False) # 将数据保存到Excel表格中,根据实际情况修改文件名和路径 ``` 这样,您就可以使用Python读取Arduino串口数据存储到Excel表格了。注意在编译上传Arduino代码之前,确保已经安装了pySerial库,这样才能成功连接和读取Arduino串口数据
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

他人是一面镜子,保持谦虚的态度

你的鼓励是我最大的动力

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

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

打赏作者

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

抵扣说明:

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

余额充值