Python实现串口通信

  

Python实现串口通信?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

串口通信是指外设和计算机间,通过数据信号线,地线,控制线等,按位进行传输数据的一种通讯方式。这种通信方式使用的数据线少,在远距离通信中可以节约通信成本,但其传输速度比并行传输低。串口是计算机上一种非常通用的设备通信协议.pyserial模块封装了Python对串口的访问,为多平台的使用提供了统一的接口。

<强>安装:

 pip3安装pyserial 

<强>测试:

两个CH340 (TTL转串口模块)接入到PC串口上,通过Python进行数据交互:

 Python实现串口通信

<强>简单串口程序实现:

进口系列#导入模块   试一试:   #端口,GNU/Linux上的/dev/ttyUSB0等或Windows上的COM3等   portx=癈OM3"   #波特率,标准值之一:50,75110134150200300600,1200,1800,2400,4800,9600,19200,38400,57600,115200   个基点=115200   #超时设置,没有:永远等待操作,0为立即返回请求结果,其他值为等待超时时间(单位为秒)   天美时=5   #打开串口,并得到串口对象   个基点,ser=serial.Serial (portx超时=天美时)      #写数据   结果=ser.write(“我是东小东“.encode (“gbk"))   print(“写总字节数:“,结果)      ser.close() #关闭串口      除了例外e:   print(“- - - - - -异常——:“,e)

<强>获取可用串口列表:

进口系列#导入模块
  
  进口serial.tools.list_ports
  port_list=列表(serial.tools.list_ports.comports ())
  打印(port_list)
  如果len (port_list)==0:
  打印(& # 39;无可用串口& # 39;)
  其他:
  因为我在范围(0,len (port_list)):
  print (port_list[我])

<强>十六进制处理:

进口系列#导入模块
  试一试:
  portx=癈OM3"
  个基点=115200
  #超时设置,没有:永远等待操作,0为立即返回请求结果,其他值为等待超时时间(单位为秒)
  天美时=没有
  个基点,ser=serial.Serial (portx超时=天美时)
  print(“串口详情参数:“,ser)
  
  #十六进制的发送
  结果=ser.write(科(0 x06) .encode (“utf-8")) #写数据
  print(“写总字节数:“,结果)
  
  #十六进制的读取
  打印(ser.read () .hex()) #读一个字节
  
  打印(“- - - - - - - - - - - - -产生绯闻。)
  ser.close() #关闭串口
  
  除了例外e:
  print(“- - - - - -异常——:“,e) 

<强>其他细节补充:

进口系列#导入模块
  试一试:
  
  #端口,GNU/Linux上的/dev/ttyUSB0等或Windows上的COM3等
  portx=癈OM3"
  #波特率,标准值之一:50,75110134150200300600,1200,1800,2400,4800,9600,19200,38400,57600,115200
  个基点=115200
  #超时设置,没有:永远等待操作,0为立即返回请求结果,其他值为等待超时时间(单位为秒)
  天美时=5
  #打开串口,并得到串口对象
  个基点,ser=serial.Serial (portx超时=天美时)
  print(“串口详情参数:“,ser)
  
  
  
  打印(ser.port) #获取到当前打开的串口名
  打印(ser.baudrate) #获取波特率
  
  结果=ser.write(“我是东小东“.encode (“gbk")) #写数据
  print(“写总字节数:“,结果)
  
  
  #打印(ser.read()) #读一个字节
  #打印(ser.read (10) .decode (“gbk")) #读十个字节
  #打印(ser.readline () .decode (“gbk")) #读一行
  #打印(ser.readlines()) #读取多行,返回列表,必须匹配超时(超时)使用
  #打印(ser.in_waiting) #获取输入缓冲区的剩余字节数
  #打印(ser.out_waiting) #获取输出缓冲区的字节数
  
  #循环接收数据,此为死循环,可用线程实现
  而真正的:
  如果ser.in_waiting:
  str=ser.read (ser)。in_waiting) .decode (“gbk")
  如果(str==癳xit"): #退出标志
  打破
  其他:
  print(“收到数据:“(str)
  
  打印(“- - - - - - - - - - - - -产生绯闻。)
  ser.close() #关闭串口
  
  
  除了例外e:
  print(“- - - - - -异常——:“,e) 

<强>部分封装:

其中读数据的封装方法并不是很好用,使用的话又得循环接收,这样反而更加复杂了

进口系列#导入模块
  进口线程
  STRGLO=?“#读取的数据
  BOOL=True #读取标志位
  
  #读数代码本体实现
  def ReadData (ser):
  全球STRGLO BOOL
  #循环接收数据,此为死循环,可用线程实现
  而BOOL:
  如果ser.in_waiting:
  STRGLO=ser.read (ser.in_waiting) .decode (“gbk")
  打印(STRGLO)
  
  
  #打开串口
  #端口,GNU/Linux上的/dev/ttyUSB0等或Windows上的COM3等
  #波特率,标准值之一:50,75110134150200300600,1200,1800,2400,4800,9600,19200,38400,57600,115200
  #超时设置,没有:永远等待操作,0为立即返回请求结果,其他值为等待超时时间(单位为秒)
  def DOpenPort (portx基点,超时):
  ret=False
  试一试:
  #打开串口,并得到串口对象
  ser=系列。串行(portx基点,超时=超时)
  #判断是否打开成功
  如果(ser.is_open):
  ret=True
  线程。线程(目标=ReadData args=(ser)) .start ()
  除了例外e:
  print(“- - - - - -异常——:“,e)
  返回ser,受潮湿腐烂
  
  
  
  #关闭串口
  def DColsePort (ser):
  全球BOOL
  BOOL=False
  ser.close ()
  
  
  
  #写数据
  def DWritePort (ser、文本):
  结果=ser.write (text.encode (“gbk")) #写数据
  返回结果
  
  
  
  
  #读数据
  def DReadPort ():
  全球STRGLO
  str=STRGLO
  STRGLO=啊?清空当次读取
  返回str
  
  
  
  if __name__==癬_main__":
  ser ret=DOpenPort(115200年“COM6",没有)
  如果(ret==True): #判断串口是否成功打开
  数=DWritePort (ser,“我是东小东,哈哈“)
  print(“写入字节数:“,计数)
  # DReadPort() #读串口数据
  # DColsePort (ser) #关闭串口

Python实现串口通信