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

作者:昊宇方 时间:2022-05-17 05:41:11 

起因:学校运河杯报了个项目,制作一个天气预测的装置。我用arduino跑了BME280模块,用蓝牙模块实现两块arduino主从机透传。但是为了分析,还需要提取出数据。因此我用python写了个上位机程序,用pyserial模块实现arduiho和电脑的串口通讯,再用xlwt模块写入excel表格,用time模块获取时间作为excel的文件名。


import xlwt
import time
import serial
#设置表格样式
def set_style(name,height,bold=False):
style = xlwt.XFStyle()
font = xlwt.Font()
font.name = name
font.bold = bold
font.color_index = 4
font.height = height
style.font = font
return style
#写Excel
def write_excel():
if serial.isOpen():
 print ('串口已打开\n')
f = xlwt.Workbook()
sheet1 = f.add_sheet('arduino_data',cell_overwrite_ok=True)
row0 = ["temp","pres","hum"]
time1=time.localtime(time.time())
#写第一行
for i in range(len(row0)):
 sheet1.write(0,i,row0[i],set_style('Times New Roman',220,True))
i=1
time.sleep(5)
serial.flushInput()
while True:
 try:
  size = serial.inWaiting()
  if size != 0:
   response = serial.read(size)  # 读取内容并显示
   s=response.decode('utf-8').rstrip('\r\n').split('\t')
   if len(s)!=3:
    serial.flushInput()
    continue
   else:
    try:
     for j in range(len(s)):
      sheet1.write(i,j,int(s[j]),set_style('Times New Roman',220,False))
     print(s)
     serial.flushInput()     # 清空接收缓存区
     i = i+1
     time.sleep(0.5)
    except ValueError:
     serial.flushInput()
     continue
 except KeyboardInterrupt:
  time2=time.localtime(time.time())
  f.save(r'C:\Users\10020\Desktop\arduino_data\{0}.{1}_{2:0>2d}.{3:0>2d}.{4:0>2d}-{5}.{6}_{7:0>2d}.{8:0>2d}.{9:0>2d}.xls'.format\
    (time1[1],time1[2],time1[3],time1[4],time1[5],
    time2[1],time2[2],time2[3],time2[4],time2[5]))
  serial.close()
  print(time1)
  print(time2)
  quit()
if __name__ == '__main__':
serial = serial.Serial('COM3',9600,timeout=2)
write_excel()

运行代码后会一直从串口读取arduino的数据,然后写入excel。按Ctrl+c来中止代码进程,此时会在C:\Users\10020\Desktop\arduino_data\这个文件夹下生成以“开始运行时间-结束运行时间”为名称的xls文件。

代码的运行效果:

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

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

 需要注意的是:

  1. 串口和波特率根据电脑上显示的COM口和设置的arduino波特率决定

  2. arduino是通过串口发送字节串到电脑,需要编码成utf-8再对字符串进行处理

  3. 每一次接受完数据要清楚数据缓存

总结

以上所述是小编给大家介绍的python Arduino串口传输数据到电脑并保存至excel表格,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:https://www.cnblogs.com/haoyufang/archive/2019/10/14/11671075.html

标签:python,arduino,串口,传输数据
0
投稿

猜你喜欢

  • 能介绍一下NameSpace常用的地方吗?

    2009-11-01 18:11:00
  • Python 类的私有属性和私有方法实例分析

    2021-06-18 05:13:47
  • 兼容主流浏览器,纯CSS下拉菜单

    2010-09-05 20:30:00
  • 一种弹出提示信息时页面背景色调改变的方法

    2008-12-01 12:22:00
  • 详解python异步编程之asyncio(百万并发)

    2022-05-09 04:44:12
  • JavaScript[对象.属性]集锦

    2020-07-08 18:05:45
  • PHP中quotemeta()函数的用法讲解

    2023-06-08 04:04:24
  • 网购中的商品评价与口碑传播-译

    2010-07-09 13:44:00
  • JavaScript Memoization

    2008-05-01 12:48:00
  • 详尽解析javascript event对象

    2008-06-08 12:25:00
  • XML简易教程之二

    2008-09-05 17:19:00
  • 阿里妈妈广告牌制作规范

    2009-07-15 13:23:00
  • asp xmlhttp下载一句话

    2013-06-30 06:47:48
  • 泛泛而谈界面视觉效果的一致性

    2010-01-05 17:05:00
  • Bowman vs Google-设计与数据彼此相互需要

    2009-08-16 16:06:00
  • 可用性研究:为文字链接扩大可点击区域

    2008-09-18 18:23:00
  • 关于设计品质保证(DQA)的几点想法

    2007-11-16 16:55:00
  • Laravel框架路由管理简单示例

    2023-11-14 13:37:26
  • 用Assets 面板为你的站点定做颜色

    2007-02-03 11:39:00
  • 功能和外观都还不错的js版幻灯片效果

    2007-08-05 12:20:00
  • asp之家 网络编程 m.aspxhome.com