python-Arduino串口传输数据到电脑并保存至excel表格

本文介绍了使用Python的pyserial模块从Arduino串口接收数据,并利用xlwt将数据写入Excel表格的过程。代码创建了一个上位机程序,实时接收Arduino通过串口发送的BME280传感器数据,数据包括温度、压力和湿度。当按下Ctrl+C时,程序会以运行时间作为文件名保存Excel文件,并关闭串口。
摘要由CSDN通过智能技术生成

起因:学校运河杯报了个项目,制作一个天气预测的装置。我用arduino跑了BME280模块,用蓝牙模块实现两块arduino主从机透传。但是为了分析,还需要提取出数据。因此我用python写了个上位机程序,用pyserial模块实现arduiho和电脑的串口通讯,再用xlwt模块写入excel表格,用time模块获取时间作为excel的文件名。
复制代码
1 import xlwt
2 import time
3 import serial
4 #设置表格样式
5 def set_style(name,height,bold=False):
6 style = xlwt.XFStyle()
7 font = xlwt.Font()
8 font.name = name
9 font.bold = bold
10 font.color_index = 4
11 font.height = height
12 style.font = font
13 return style
14
15 #写Excel
16 def write_excel():
17 if serial.isOpen():
18 print (‘串口已打开\n’)
19 f = xlwt.Workbook()
20 sheet1 = f.add_sheet(‘arduino_data’,cell_overwrite_ok=True)
21 row0 = [“temp”,“pres”,“hum”]
22 time1=time.localtime(time.time())
23 #写第一行
24 for i in range(len(row0)):
25 sheet1.write(0,i,row

### 回答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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值