Python 串列埠通訊的實現
阿新 • • 發佈:2020-10-02
串列埠通訊是指外設和計算機間,通過資料訊號線 、地線、控制線等,按位進行傳輸資料的一種通訊方式。這種通訊方式使用的資料線少,在遠距離通訊中可以節約通訊成本,但其傳輸速度比並行傳輸低。串列埠是計算機上一種非常通用的裝置通訊協議。pyserial模組封裝了python對串列埠的訪問,為多平臺的使用提供了統一的介面。
安裝:
pip3 install pyserial
測試:
兩個CH340 (TTL轉串列埠模組)接入到PC串列埠上,通過Python進行資料互動:
簡單串列埠程式實現:
import serial #匯入模組 try: #埠,GNU / Linux上的/ dev / ttyUSB0 等 或 Windows上的 COM3 等 portx="COM3" #波特率,標準值之一:50,75,110,134,150,200,300,600,1200,1800,2400,4800,9600,19200,38400,57600,115200 bps=115200 #超時設定,None:永遠等待操作,0為立即返回請求結果,其他值為等待超時時間(單位為秒) timex=5 # 開啟串列埠,並得到串列埠物件 ser=serial.Serial(portx,bps,timeout=timex) # 寫資料 result=ser.write("我是東小東".encode("gbk")) print("寫總位元組數:",result) ser.close()#關閉串列埠 except Exception as e: print("---異常---:",e)
獲取可用串列埠列表:
import serial #匯入模組 import serial.tools.list_ports port_list = list(serial.tools.list_ports.comports()) print(port_list) if len(port_list) == 0: print('無可用串列埠') else: for i in range(0,len(port_list)): print(port_list[i])
十六進位制處理:
import serial #匯入模組 try: portx="COM3" bps=115200 #超時設定,None:永遠等待操作,0為立即返回請求結果,其他值為等待超時時間(單位為秒) timex=None ser=serial.Serial(portx,timeout=timex) print("串列埠詳情引數:",ser) #十六進位制的傳送 result=ser.write(chr(0x06).encode("utf-8"))#寫資料 print("寫總位元組數:",result) #十六進位制的讀取 print(ser.read().hex())#讀一個位元組 print("---------------") ser.close()#關閉串列埠 except Exception as e: print("---異常---:",e)
其他細節補充:
import serial #匯入模組 try: #埠,GNU / Linux上的/ dev / ttyUSB0 等 或 Windows上的 COM3 等 portx="COM3" #波特率,標準值之一:50,ser) print(ser.port)#獲取到當前開啟的串列埠名 print(ser.baudrate)#獲取波特率 result=ser.write("我是東小東".encode("gbk"))#寫資料 print("寫總位元組數:",result) #print(ser.read())#讀一個位元組 # print(ser.read(10).decode("gbk"))#讀十個位元組 #print(ser.readline().decode("gbk"))#讀一行 #print(ser.readlines())#讀取多行,返回列表,必須匹配超時(timeout)使用 #print(ser.in_waiting)#獲取輸入緩衝區的剩餘位元組數 #print(ser.out_waiting)#獲取輸出緩衝區的位元組數 #迴圈接收資料,此為死迴圈,可用執行緒實現 while True: if ser.in_waiting: str=ser.read(ser.in_waiting ).decode("gbk") if(str=="exit"):#退出標誌 break else: print("收到資料:",str) print("---------------") ser.close()#關閉串列埠 except Exception as e: print("---異常---:",e)
部分封裝:
其中讀資料的封裝方法並不是很好用,使用的話又得迴圈接收,這樣反而更加複雜了
import serial #匯入模組 import threading STRGLO="" #讀取的資料 BOOL=True #讀取標誌位 #讀數程式碼本體實現 def ReadData(ser): global STRGLO,BOOL # 迴圈接收資料,此為死迴圈,可用執行緒實現 while BOOL: if ser.in_waiting: STRGLO = ser.read(ser.in_waiting).decode("gbk") print(STRGLO) #開啟串列埠 # 埠,GNU / Linux上的/ dev / ttyUSB0 等 或 Windows上的 COM3 等 # 波特率,標準值之一:50,115200 # 超時設定,None:永遠等待操作,0為立即返回請求結果,其他值為等待超時時間(單位為秒) def DOpenPort(portx,timeout): ret=False try: # 開啟串列埠,並得到串列埠物件 ser = serial.Serial(portx,timeout=timeout) #判斷是否開啟成功 if(ser.is_open): ret=True threading.Thread(target=ReadData,args=(ser,)).start() except Exception as e: print("---異常---:",e) return ser,ret #關閉串列埠 def DColsePort(ser): global BOOL BOOL=False ser.close() #寫資料 def DWritePort(ser,text): result = ser.write(text.encode("gbk")) # 寫資料 return result #讀資料 def DReadPort(): global STRGLO str=STRGLO STRGLO=""#清空當次讀取 return str if __name__=="__main__": ser,ret=DOpenPort("COM6",115200,None) if(ret==True):#判斷串列埠是否成功開啟 count=DWritePort(ser,"我是東小東,哈哈") print("寫入位元組數:",count) #DReadPort() #讀串列埠資料 #DColsePort(ser) #關閉串列埠
檢視所有串列埠
import serial.tools.list_ports port_list = list(serial.tools.list_ports.comports()) if len(port_list) == 0: print('找不到串列埠') else: for i in range(0,len(port_list)): print(port_list[i])
參考:
https://pythonhosted.org/pyserial/pyserial_api.html#serial.Serial.open
以上就是Python 串列埠通訊的實現的詳細內容,更多關於python 串列埠通訊的資料請關注我們其它相關文章!