1. 程式人生 > 實用技巧 >NO.A.0003——打造企業級的lnmp web架構實戰——yum

NO.A.0003——打造企業級的lnmp web架構實戰——yum

起因:學校運河杯報了個專案,製作一個天氣預測的裝置。我用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檔案。

程式碼的執行效果:

需要注意的是:

  1. 串列埠和波特率根據電腦上顯示的COM口和設定的arduino波特率決定
  2. arduino是通過串列埠傳送位元組串到電腦,需要編碼成utf-8再對字串進行處理
  3. 每一次接受完資料要清楚資料快取

總結

以上所述是小編給大家介紹的python Arduino串列埠傳輸資料到電腦並儲存至excel表格,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對碼農教程網站的支援!

如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!