起因:学校运河杯报了个项目,制作一个天气预测的装置。我用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文件。
代码的运行效果:
需要注意的是:
- 串口和波特率根据电脑上显示的COM口和设置的arduino波特率决定
- arduino是通过串口发送字节串到电脑,需要编码成utf-8再对字符串进行处理
- 每一次接受完数据要清楚数据缓存
总结
以上所述是小编给大家介绍的python Arduino串口传输数据到电脑并保存至excel表格,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。