时间:2022-03-08 10:18:12 | 栏目:Python代码 | 点击:次
通过两个进程分别读写串口,并把发送与接收到的内容记录在blog中,收到q时程序结束并退出
import threading,time import serial import string class SerThread: def __init__(self, Port=0): #初始化串口、blog文件名称 self.my_serial = serial.Serial() self.my_serial.port=Port self.my_serial.baudrate = 9600 self.my_serial.timeout = 1 self.alive = False self.waitEnd = None fname=time.strftime("%Y%m%d")#blog名称为当前时间 self.rfname='r'+fname #接收blog名称 self.sfname='s'+fname #发送blog名称 self.thread_read= None self.thread_send=None def waiting(self): # 等待event停止标志 if not self.waitEnd is None: self.waitEnd.wait() def start(self): #开串口以及blog文件 self.rfile=open(self.rfname,'w') self.sfile=open(self.sfname,'w') self.my_serial.open() if self.my_serial.isOpen(): self.waitEnd = threading.Event() self.alive = True self.thread_read = threading.Thread(target=self.Reader) self.thread_read.setDaemon(True) self.thread_send=threading.Thread(target=self.Sender) self.thread_send.setDaemon(True) self.thread_read.start() self.thread_send.start() return True else: return False def Reader(self): while self.alive: try: n=self.my_serial.inWaiting() data='' if n: data= self.my_serial.read(n).decode('utf-8') print ('recv'+' '+time.strftime("%Y-%m-%d %X")+' '+data.strip()) print (time.strftime("%Y-%m-%d %X:")+data.strip(),file=self.rfile) if len(data)==1 and ord(data[len(data)-1])==113: #收到字母q,程序退出 break except Exception as ex: print (ex) self.waitEnd.set() self.alive = False def Sender(self): while self.alive: try: snddata=input("input data:\n") self.my_serial.write(snddata.encode('utf-8')) print ('sent'+' '+ time.strftime("%Y-%m-%d %X")) print (snddata,file=self.sfile) except Exception as ex: print (ex) self.waitEnd.set() self.alive = False def stop(self): self.alive = False #self.thread_read.join() #self.thread_send.join() if self.my_serial.isOpen(): self.my_serial.close() self.rfile.close() self.sfile.close() if __name__ == '__main__': ser = SerThread('com4') try: if ser.start(): ser.waiting() ser.stop() else: pass; except Exception as ex: print (ex) if ser.alive: ser.stop() print ('End OK .'); del ser;