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


Posted in Python onOctober 14, 2019

起因:学校运河杯报了个项目,制作一个天气预测的装置。我用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表格,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
详解Python中的type()方法的使用
May 21 Python
Python开发的HTTP库requests详解
Aug 29 Python
python批量修改图片后缀的方法(png到jpg)
Oct 25 Python
基于Python对数据shape的常见操作详解
Dec 25 Python
Python 使用 attrs 和 cattrs 实现面向对象编程的实践
Jun 12 Python
PyQt5 实现给窗口设置背景图片的方法
Jun 13 Python
简单的Python调度器Schedule详解
Aug 30 Python
Python实现TCP探测目标服务路由轨迹的原理与方法详解
Sep 04 Python
Python3.x+迅雷x 自动下载高分电影的实现方法
Jan 12 Python
如何在scrapy中集成selenium爬取网页的方法
Nov 18 Python
python数据分析之用sklearn预测糖尿病
Apr 22 Python
pytorch 6 batch_train 批训练操作
May 28 Python
python实现文件批量编码转换及注意事项
Oct 14 #Python
python 正则表达式贪婪模式与非贪婪模式原理、用法实例分析
Oct 14 #Python
Python协程操作之gevent(yield阻塞,greenlet),协程实现多任务(有规律的交替协作执行)用法详解
Oct 14 #Python
Python 闭包,函数分隔作用域,nonlocal声明非局部变量操作示例
Oct 14 #Python
win10子系统python开发环境准备及kenlm和nltk的使用教程
Oct 14 #Python
python web框架Flask实现图形验证码及验证码的动态刷新实例
Oct 14 #Python
执行Django数据迁移时报 1091错误及解决方法
Oct 14 #Python
You might like
用PHP编写PDF文档生成器
2006/10/09 PHP
怎样在UNIX系统下安装MySQL
2006/10/09 PHP
根据分辨率不同,调用不同的css文件
2006/07/07 Javascript
开发跨浏览器javascript常见注意事项
2009/01/01 Javascript
jQuery TextBox自动完成条
2009/07/22 Javascript
js 小数取整的函数
2010/05/10 Javascript
简单js代码实现selece二级联动(推荐)
2014/02/18 Javascript
javascript生成随机颜色示例代码
2014/05/05 Javascript
我的Node.js学习之路(一)
2014/07/06 Javascript
JavaScript极简入门教程(二):对象和函数
2014/10/25 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【二】
2016/05/10 Javascript
jQuery mobile在页面加载时添加加载中效果 document.ready 和window.onload执行顺序比较
2016/07/14 Javascript
浅谈js中调用函数时加不加括号的问题
2016/07/28 Javascript
jQuery实现表格奇偶行显示不同背景色 就这么简单
2017/03/13 Javascript
p5.js入门教程之图片加载
2018/03/20 Javascript
nodejs实现范围请求的实现代码
2018/10/12 NodeJs
Element-ui自定义table表头、修改列标题样式、添加tooltip、:render-header使用
2019/04/11 Javascript
JS实现纵向轮播图(初级版)
2020/01/18 Javascript
python实现登陆知乎获得个人收藏并保存为word文件
2015/03/16 Python
Python实现Sqlite将字段当做索引进行查询的方法
2016/07/21 Python
30秒轻松实现TensorFlow物体检测
2018/03/14 Python
Python地图绘制实操详解
2019/03/04 Python
python opencv摄像头的简单应用
2019/06/06 Python
Python使用pyserial进行串口通信的实例
2019/07/02 Python
python opencv调用笔记本摄像头
2019/08/28 Python
win10子系统python开发环境准备及kenlm和nltk的使用教程
2019/10/14 Python
20行Python代码实现视频字符化功能
2020/04/13 Python
浅谈django 重载str 方法
2020/05/19 Python
一款纯css3实现的非常实用的鼠标悬停特效演示
2014/11/05 HTML / CSS
德国大型的家具商店:Pharao24.de
2016/10/02 全球购物
Madewell澳大利亚官方网站:美国休闲服饰品牌
2019/07/18 全球购物
精伦电子Java笔试题
2013/01/16 面试题
行政专员工作职责
2013/12/22 职场文书
致跳高运动员广播稿
2014/01/13 职场文书
签订劳动合同通知书
2015/04/16 职场文书
JMeter对MySQL数据库进行压力测试的实现步骤
2022/01/22 MySQL