python-Arduino串口传输数据到电脑并保存至excel表格
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python-Arduino串口传输数据到电脑并保存至excel表格,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2839字,纯文字阅读大概需要5分钟。
内容图文
![python-Arduino串口传输数据到电脑并保存至excel表格](/upload/InfoBanner/zyjiaocheng/690/74ee4b8bef504ada8b4302ff199d1979.jpg)
起因:学校运河杯报了个项目,制作一个天气预测的装置。我用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,row0[i],set_style('Times New Roman',220,True)) 26 i=1 27 time.sleep(5) 28 serial.flushInput() 29 while True: 30 try: 31 size = serial.inWaiting() 32 if size != 0: 33 response = serial.read(size) # 读取内容并显示 34 s=response.decode('utf-8').rstrip('\r\n').split('\t') 35 if len(s)!=3: 36 serial.flushInput() 37 continue 38 else: 39 try: 40 for j in range(len(s)): 41 sheet1.write(i,j,int(s[j]),set_style('Times New Roman',220,False)) 42 print(s) 43 serial.flushInput() # 清空接收缓存区 44 i = i+1 45 time.sleep(0.5) 46 except ValueError: 47 serial.flushInput() 48 continue 49 except KeyboardInterrupt: 50 time2=time.localtime(time.time()) 51 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'.format52 (time1[1],time1[2],time1[3],time1[4],time1[5], 53 time2[1],time2[2],time2[3],time2[4],time2[5])) 54 serial.close() 55 print(time1) 56 print(time2) 57 quit() 58 59 if __name__ == '__main__': 60 serial = serial.Serial('COM3',9600,timeout=2) 61 write_excel()
运行代码后会一直从串口读取arduino的数据,然后写入excel。按Ctrl+c来中止代码进程,此时会在C:\Users\10020\Desktop\arduino_data\这个文件夹下生成以“开始运行时间-结束运行时间”为名称的xls文件。
代码的运行效果:
需要注意的是:
- 串口和波特率根据电脑上显示的COM口和设置的arduino波特率决定
- arduino是通过串口发送字节串到电脑,需要编码成utf-8再对字符串进行处理
- 每一次接受完数据要清楚数据缓存
2019-10-14-14:44:49
内容总结
以上是互联网集市为您收集整理的python-Arduino串口传输数据到电脑并保存至excel表格全部内容,希望文章能够帮你解决python-Arduino串口传输数据到电脑并保存至excel表格所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。