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实现在某个数组中查找一个值的算法示例
Jun 27 Python
Python通过paramiko远程下载Linux服务器上的文件实例
Dec 27 Python
Python2和Python3之间的str处理方式导致乱码的讲解
Jan 03 Python
Python实现微信消息防撤回功能的实例代码
Apr 29 Python
Python人脸识别第三方库face_recognition接口说明文档
May 03 Python
python调用支付宝支付接口流程
Aug 15 Python
基于python的BP神经网络及异或实现过程解析
Sep 30 Python
Python操作Sqlite正确实现方法解析
Feb 05 Python
Keras load_model 导入错误的解决方式
Jun 09 Python
详解在Python中使用Torchmoji将文本转换为表情符号
Jul 27 Python
python实现单机五子棋
Aug 28 Python
python 实现音频叠加的示例
Oct 29 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
一个颜色轮换的简单例子
2006/10/09 PHP
php中在PDO中使用事务(Transaction)
2011/05/14 PHP
php中使用Ajax时出现Error(c00ce56e)的详细解决方案
2014/11/03 PHP
ThinkPHP通过AJAX返回JSON的两种实现方法
2014/12/18 PHP
php解析字符串里所有URL地址的方法
2015/04/03 PHP
jquery的ajax简单结构示例代码
2014/02/17 Javascript
推荐一个封装好的getElementsByClassName方法
2014/12/02 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
VC调用javascript的几种方法(推荐)
2016/08/09 Javascript
Bootstrap 3的box-sizing样式导致UEditor控件的图片无法正常缩放的解决方案
2016/09/15 Javascript
学习Node.js模块机制
2016/10/17 Javascript
JavaScript数据结构学习之数组、栈与队列
2017/05/02 Javascript
详解node.js中的npm和webpack配置方法
2018/01/21 Javascript
Vue CLI 3搭建vue+vuex最全分析(推荐)
2018/09/27 Javascript
vue实现行列转换的一种方法
2019/08/06 Javascript
Nuxt配置Element-UI按需引入的操作方法
2020/07/06 Javascript
[38:31]完美世界DOTA2联赛PWL S3 Magma vs GXR 第一场 12.13
2020/12/17 DOTA
Python开发如何在ubuntu 15.10 上配置vim
2016/01/25 Python
scrapy-redis的安装部署步骤讲解
2019/02/27 Python
简单介绍python封装的基本知识
2019/08/10 Python
pytorch的梯度计算以及backward方法详解
2020/01/10 Python
python使用opencv resize图像不进行插值的操作
2020/07/05 Python
Python Matplotlib简易教程(小白教程)
2020/07/28 Python
基于Python爬取素材网站音频文件
2020/10/21 Python
Python+OpenCV图像处理——实现轮廓发现
2020/10/23 Python
利用CSS3的transform做的动态时钟效果
2011/09/21 HTML / CSS
详解如何使用CSS3中的结构伪类选择器和伪元素选择器
2020/01/06 HTML / CSS
关于iframe跨域使用postMessage的实现
2019/10/29 HTML / CSS
预备党员思想汇报
2014/01/08 职场文书
幼儿园秋游活动方案
2014/01/21 职场文书
药剂专业自荐信范文
2014/04/16 职场文书
创业培训计划书
2014/05/03 职场文书
2014组织生活会方案
2014/05/19 职场文书
医院保洁服务方案
2014/06/11 职场文书
学生通报表扬范文
2015/05/04 职场文书
2015年党建工作汇报材料
2015/06/25 职场文书