python库之pyserial用法,pyserial和serial的区别

参考链接:

  1. Welcome to pySerial’s documentation — pySerial 3.4 documentation
  2. GitHub - pyserial/pyserial: Python serial port access library

API详细内容参见链接1。
链接2 is part of pySerial.

目录

  • pyserial和serial的区别
  • pyserial库
    • 示例
      • 官方示例
      • 打开串口示例
      • 写入串口示例
      • 读取串口示例
      • 发送串口命令示例
    • 常见pySerial API(Native ports)
      • serial.Serial()
      • open()
      • close()
      • __ del __()
      • read(size=1)
      • read_until(expected=LF, size=None)
      • write(data)
      • flush()
      • in_waiting
      • out_waiting
      • rts
      • dtr
      • is_open
      • port
      • baudrate
      • bytesize
      • parity
      • stopbits
      • timeout
      • write_timeout
      • readable()
      • writable()
      • seekable()
      • readinto(b)
      • readline(size=-1)
      • readlines(hint=-1)
      • writelines(lines)
  • serial库

pyserial和serial的区别

准确的区别不清楚,但可以说明,python3版本以上涉及串行端口访问的应用均使用pyserial库,不需要serial库。
不过在python程序中,要import serial。但实际上settings中不安装serial,只需pyserial。(实践可知)
参见python用pyserial读取串口问题解决_Electrical_IT的博客-CSDN博客 https://blog.csdn.net/Electrical_IT/article/details/107221567
(欢迎在留言区指正 ! )

pyserial库

This module encapsulates the access for the serial port. It provides backends for Python running on Windows, OSX, Linux, BSD (possibly any POSIX compliant system) and IronPython. The module named “serial” automatically selects the appropriate backend.
该模块封装了对串行端口的访问。 它提供了在Windows,OSX,Linux,BSD(可能是任何POSIX兼容系统)和IronPython上运行的Python的后端。 名为“串行”的模块会自动选择适当的后端。

安装:
在Windows的cmd命令中输入 ‘pip install pyserial’,即可安装pyserial。
或者
在conda运行:‘conda install -c conda-forge pyserial’
适用于linux, mac 和windows系统.

示例

官方示例

The port is opened automatically:
(Changed in version 3.4: the port is automatically opened)

>>> port = serial.Serial()
>>> port.port = '...'
>>> with port as s:
...     s.write(b'hello')

打开串口示例

除此示例外,其他示例省略import serial、ser定义和close()等必要程序,请自行补全,灵活使用。

import serial // 安装pyserial,但import serial,且不能安装serial

# ser为串口对象,后续调用均用点运算符
ser = serial.Serial('COM7', 3000000, 8, 'N', 1) # 'COM7', 3000000, bytesize=8, parity='N', stopbits=1
flag = ser.is_open

if flag:
	print('success\n')
	ser.close()
else:
	print('Open Error\n')

写入串口示例

向串口ser写入help字符串:

ser.write("help".encode('utf-8'))

注意,字符串要编码成utf-8,否则会报错,详细参考下文中的write(data)说明。

读取串口示例

读取串口4个字节的数据:

print(ser.read(4))

发送串口命令示例

发送命令help:

command = "help\n"   # 命令要加\n,否则识别为普通字符串
ser.write(command.encode('utf-8'))   # 命令也同样要编码

常见pySerial API(Native ports)


serial.Serial()

class serial.Serial __init __(port=None, baudrate=9600, bytesize=EIGHTBITS, parity=PARITY_NONE, stopbits=STOPBITS_ONE, timeout=None, xonxoff=False, rtscts=False, write_timeout=None, dsrdtr=False, inter_byte_timeout=None, exclusive=None)

  • Parameters:
    port – Device name or None.
    baudrate (int) – Baud rate such as 9600 or 115200 etc.
    bytesize – Number of data bits. Possible values: FIVEBITS, SIXBITS, SEVENBITS, EIGHTBITS
    parity – Enable parity checking. Possible values: PARITY_NONE, PARITY_EVEN, PARITY_ODD PARITY_MARK, PARITY_SPACE
    stopbits – Number of stop bits. Possible values: STOPBITS_ONE, STOPBITS_ONE_POINT_FIVE, STOPBITS_TWO
    timeout (float) – Set a read timeout value.
    xonxoff (bool) – Enable software flow control.
    rtscts (bool) – Enable hardware (RTS/CTS) flow control.
    dsrdtr (bool) – Enable hardware (DSR/DTR) flow control.
    write_timeout (float) – Set a write timeout value.
    inter_byte_timeout (float) – Inter-character timeout, None to disable (default).
    exclusive (bool) – Set exclusive access mode (POSIX only). A port cannot be opened in exclusive access mode if it is already open in exclusive access mode.

  • 参数(翻译):
    port–设备名称或无。
    baudrate(int)–波特率,例如9600或115200等。
    bytesize –数据位数。 可能的值:五位,六位,七位,八位
    parity–奇偶校验。 可能的值:PARITY_NONE,PARITY_EVEN,PARITY_ODD,PARITY_MARK,PARITY_SPACE
    stopbits –停止位的数量。 可能的值:STOPBITS_ONE,STOPBITS_ONE_POINT_FIVE,STOPBITS_TWO
    timeout(浮动)–设置读取超时值。
    xonxoff(布尔)–启用软件流控制。
    rtscts(布尔)–启用硬件(RTS / CTS)流控制。
    dsrdtr(布尔)–启用硬件(DSR / DTR)流控制。
    write_timeout(浮点型)–设置写超时值。
    inter_byte_timeout(浮点型)–字符间超时,无则禁用(默认)。
    exclusive(布尔)–设置独占访问模式(仅POSIX)。 如果端口已经以独占访问模式打开,则不能以独占访问模式打开端口。
    给定端口后,将在创建对象时立即打开该端口。 当端口为None且需要连续调用open()时,不会打开它。

  • Raises:
    ValueError – Will be raised when parameter are out of range, e.g. baud rate, data bits.
    SerialException – In case the device can not be found or can not be configured.
    ValueError –当参数超出范围时会引发,例如 波特率,数据位。
    SerialException –如果找不到或无法配置设备。

端口是设备名称:取决于操作系统。 例如 在GNU / Linux上为/ dev / ttyUSB0,在Windows上为COM3。

参数波特率可以是以下标准值之一:50、75、110、134、150、200、300、600、1200、1800、2400、4800、9600、19200、38400、57600、115200。 (取决于平台)

115200以上的标准值,例如:230400、460800、500000、576000、921600、1000000、1152000、1500000、2000000、2500000、3000000、3500000、4000000也可在许多平台和设备上运行。

在某些平台(GNU / Linux,MAC OSX> = Tiger,Windows)上也支持非标准值。 但是,即使在这些平台上,某些串行端口也可能拒绝非标准值。

控制read()行为的参数timeout的取值:

  • timeout=无:永远等待/直到收到请求的字节数
  • timeout= 0:非阻塞模式,在任何情况下立即返回,返回零个或多个,直到请求的字节数
  • timeout= x:将timeout设置为x秒(允许浮动),当请求的字节数可用时立即返回,否则请等待直到超时到期并返回直到那时为止接收到的所有字节。

除非设置了write_timeout,否则默认情况下write()处于阻塞状态。 可能的取值,请参考上面的timeout。

请注意,可能不支持同时启用两种流控制方法(xonxoff和rtscts)。 通常一次使用一种方法,而不是同时使用。

并非所有平台都支持dsrdtr(已被忽略)。 将其设置为None会导致其状态遵循rtscts。

还可以考虑使用函数serial_for_url()代替直接创建Serial实例。

open()

打开端口。 将应用rts和dtr的状态。

注:打开端口后,某些操作系统和/或驱动程序可能会自动激活RTS或DTR。 当rts或dtr的设置与默认值不同时(True / active),RTS / DTR可能会出现故障。

close()

立即关闭端口。

__ del __()

析构函数,在释放串行端口实例时关闭端口。

read(size=1)

读取串口(默认读取字节大小= 1)

  • Parameters:
    size – Number of bytes to read.
    Returns: Bytes read from the port.
    Return type: bytes
  • 参数:
    size –要读取的字节数。
    返回:从端口读取的字节。
    返回类型:字节

Read size bytes from the serial port. If a timeout is set it may return less characters as requested. With no timeout it will block until the requested number of bytes is read.
从串行端口读取大小字节。 如果设置了超时,它可能会根据要求返回更少的字符。 没有超时,它将阻塞直到读取请求的字节数。

read_until(expected=LF, size=None)

read_until(期望= LF,大小=无)

  • Parameters:
    expected – The byte string to search for.
    size – Number of bytes to read.
    Returns: Bytes read from the port.
    Return type: bytes
  • 参数:
    预期–要搜索的字节字符串。
    size –要读取的字节数。
    返回值:从端口读取的字节。
    返回类型:字节

Read until an expected sequence is found (‘\n’ by default), the size is exceeded or until timeout occurs. If a timeout is set it may return less characters as requested. With no timeout it will block until the requested number of bytes is read.
读取直到找到期望的序列(默认为“ \ n”),超出大小或直到发生超时为止。 如果设置了超时,它可能会根据要求返回更少的字符。 若没有超时,它将阻塞直到读取请求的字节数。

write(data)

写(数据)

  • Parameters: data – Data to send.
    Returns: Number of bytes written.
    Return type: int
    Raises: SerialTimeoutException – In case a write timeout is configured for the port and the time is exceeded.

  • 参数:data –要发送的数据。
    返回:写入的字节数。
    返回类型:int
    引发:SerialTimeoutException-如果为端口配置了写超时并且超过了时间。

将字节数据写入端口。 数据应该是字节类型(或兼容的,例如字节数组或内存视图)。 Unicode字符串必须经过编码(例如’hello’.encode(‘utf-8’)

flush()

Flush of file like objects. In this case, wait until all data is written.
清除文件一样的对象。 在这种情况下,请等待所有数据写入后执行。

in_waiting

Getter:获取输入缓冲区中的字节数
类型:int
返回接收缓冲区中的字节数。

out_waiting

Getter:获取输出缓冲区中的字节数
类型:int
平台:Posix
平台:Windows
返回输出缓冲区中的字节数。

rts

设置器:设置RTS线路的状态
Getter:返回RTS线路的状态
类型:布尔
将RTS线路设置为指定的逻辑电平。 可以在打开串行端口之前分配此值,然后在open()上应用该值(有限制,请参见open())。

dtr

设置器:设置DTR线的状态
Getter:返回DTR线的状态
类型:布尔
将DTR线设置为指定的逻辑电平。 可以在打开串行端口之前分配此值,然后在open()上应用该值(有限制,请参见open())。


is_open

只读
Getter:获取串行端口的状态,判断它是否打开。
类型:布尔


New values can be assigned to the following attributes (properties), the port will be reconfigured, even if it’s opened at that time:
可以将新值分配给以下属性(属性),即使端口当时已打开,也将对其进行重新配置:

port

类型:str
读取或写入端口。当端口已经打开时,它将被关闭并使用新设置重新打开。

baudrate

Getter:获取当前波特率
设置器:设置新的波特率
类型:int
读取或写入当前波特率设置。

bytesize

Getter:获取当前字节大小
设置器:设置新的字节大小。可能的值:FIVEBITS, SIXBITS, SEVENBITS, EIGHTBITS
类型:int
读取或写入当前数据字节大小设置。

parity

Getter:获取当前的奇偶校验设置
设置器:设置新的奇偶校验模式。可能的值:PARITY_NONE,PARITY_EVEN,PARITY_ODD,PARITY_MARK,PARITY_SPACE
读取或写入当前的奇偶校验设置。

stopbits

Getter:获取当前的停止位设置
设置器:设置新的停止位设置。可能的值:STOPBITS_ONE,STOPBITS_ONE_POINT_FIVE,STOPBITS_TWO
读取或写入当前停止位宽度设置。

timeout

Getter:获取当前读取超时设置
设置器:设置读取超时
类型:浮点(秒)
读取或写入当前读取超时设置。

write_timeout

Getter:获取当前写入超时设置
设置器:设置写超时
类型:浮点(秒)
读取或写入当前写入超时设置。


以下方法用于与io库兼容。

readable()

可读的
返回:True
2.5版的新功能。

writable()

可写的
返回:True
2.5版的新功能。

seekable()

返回:False
2.5版的新功能。

readinto(b)

读入(b)

  • Parameters: b – bytearray or array instance
    Returns: Number of byte read
    参数:b-字节数组或数组实例
    返回:读取的字节数
  • Read up to len(b) bytes into bytearray b and return the number of bytes read.
    读取len(b)个字节到字节数组b中,并返回读取的字节数。

2.5版的新功能。

readline(size=-1)

readline(大小= -1)
读取串口数据中的一行

通过io.IOBase.readline()提供

readlines(hint=-1)

readlines(提示= -1)
将串口数据的每一行全部读取,放在一个一维字符串数组中,每个数组元素是一行字符串。

通过io.IOBase.readlines()提供

writelines(lines)

通过io.IOBase.writelines()提供


serial库

serial 0.0.97

A framework for serializing/deserializing JSON/YAML/XML into python class instances and vice versa
一个将JSON / YAML / XML序列化/反序列化为python类实例的框架,反之亦然

你可能感兴趣的:(库)