python 中Arduino串口傳輸數(shù)據(jù)到電腦并保存至excel表格
起因:學(xué)校運(yùn)河杯報了個項(xiàng)目,制作一個天氣預(yù)測的裝置。我用arduino跑了BME280模塊,用藍(lán)牙模塊實(shí)現(xiàn)兩塊arduino主從機(jī)透傳。但是為了分析,還需要提取出數(shù)據(jù)。因此我用python寫了個上位機(jī)程序,用pyserial模塊實(shí)現(xiàn)arduiho和電腦的串口通訊,再用xlwt模塊寫入excel表格,用time模塊獲取時間作為excel的文件名。
import xlwt
import time
import serial
#設(shè)置表格樣式
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) # 讀取內(nèi)容并顯示
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() # 清空接收緩存區(qū)
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()
運(yùn)行代碼后會一直從串口讀取arduino的數(shù)據(jù),然后寫入excel。按Ctrl+c來中止代碼進(jìn)程,此時會在C:\Users\10020\Desktop\arduino_data\這個文件夾下生成以“開始運(yùn)行時間-結(jié)束運(yùn)行時間”為名稱的xls文件。
代碼的運(yùn)行效果:


需要注意的是:
- 串口和波特率根據(jù)電腦上顯示的COM口和設(shè)置的arduino波特率決定
- arduino是通過串口發(fā)送字節(jié)串到電腦,需要編碼成utf-8再對字符串進(jìn)行處理
- 每一次接受完數(shù)據(jù)要清楚數(shù)據(jù)緩存
總結(jié)
以上所述是小編給大家介紹的python Arduino串口傳輸數(shù)據(jù)到電腦并保存至excel表格,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
Python數(shù)據(jù)分析之?Pandas?Dataframe條件篩選遍歷詳情
這篇文章主要介紹了Python數(shù)據(jù)分析之?Pandas?Dataframe條件篩選遍歷詳情,查詢Pandas?Dataframe數(shù)據(jù)時,經(jīng)常會篩選出符合條件的數(shù)據(jù),關(guān)于其使用方式,需要的小伙伴可以參考一下下面文章內(nèi)容2022-05-05
Python+PyQt5實(shí)現(xiàn)自動點(diǎn)擊神器
這篇文章主要為大家詳細(xì)介紹了如何利用Python和PyQt5實(shí)現(xiàn)自動點(diǎn)擊神器,旨在解決重復(fù)性的點(diǎn)擊工作,解放雙手,具有及時性和準(zhǔn)確性,需要的可以參考下2024-01-01
在python2.7中用numpy.reshape 對圖像進(jìn)行切割的方法
今天小編就為大家分享一篇在python2.7中用numpy.reshape 對圖像進(jìn)行切割的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12
Python3 assert斷言實(shí)現(xiàn)原理解析
這篇文章主要介紹了Python3 assert斷言實(shí)現(xiàn)原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03
使用Pandas將inf, nan轉(zhuǎn)化成特定的值
今天小編就為大家分享一篇使用Pandas將inf, nan轉(zhuǎn)化成特定的值,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
Python下應(yīng)用opencv 實(shí)現(xiàn)人臉檢測功能
OpenCV是如今最流行的計(jì)算機(jī)視覺庫,今天我們通過本文給大家分享Python下應(yīng)用opencv 實(shí)現(xiàn)人臉檢測功能,感興趣的朋友跟隨小編一起看看吧2019-10-10
Python爬蟲使用瀏覽器cookies:browsercookie過程解析
這篇文章主要介紹了Python爬蟲使用瀏覽器cookies:browsercookie,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-10-10

