NO.A.0003——打造企業級的lnmp web架構實戰——yum
阿新 • • 發佈:2020-11-18
起因:學校運河杯報了個專案,製作一個天氣預測的裝置。我用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表格,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對碼農教程網站的支援!