Python在Windows上驱动串口主要依靠跨平台、稳定的pyserial库;需安装后用comports()扫描COM端口,再以bytes收发数据并注意编码解码与异常处理。

Python 在 Windows 上驱动串口,主要靠 pyserial 库,它跨平台、稳定、文档清晰,是事实标准。
安装 pyserial
打开命令提示符或 PowerShell,运行:
pip install pyserial
验证是否成功:
python -c "import serial; print(serial.__version__)"
列出可用串口(Windows 下常见为 COM1、COM3 等)
Windows 不像 Linux 有 /dev/tty*,需主动扫描。常用方法:
立即学习“Python免费学习笔记(深入)”;
- 用
serial.tools.list_ports.comports()获取所有已识别的串口及描述 - 过滤出带 “USB” 或 “CH340”“CP210” 等关键词的端口(常见 USB 转串口芯片)
示例代码:
import serial.tools.list_ports
<p>for port in serial.tools.list_ports.comports():
print(f"{port.device} — {port.description}")
打开串口并收发数据
关键参数:端口号(如 'COM3')、波特率(如 9600)、字节大小、停止位、校验等。最简通信示例如下:
import serial
<h1>打开串口(超时设为 1 秒,避免阻塞)</h1><p>ser = serial.Serial('COM3', 9600, timeout=1)</p><h1>发送字节(注意:必须是 bytes,不是 str)</h1><p>ser.write(b'hello\r\n')</p><h1>读取最多 100 字节(返回 bytes)</h1><p>data = ser.read(100)
print(data.decode('utf-8', errors='ignore'))</p><p>ser.close() # 用完务必关闭
常见注意事项:
- Windows 下端口名区分大小写不敏感,但建议统一用大写(如
'COM3') - 发送字符串前需编码:
'abc'.encode()或直接写b'abc' - 接收数据是
bytes,打印前建议.decode('utf-8', errors='ignore')防乱码 - 若报错
PermissionError: Access is denied,说明串口被其他程序(如串口助手、Arduino IDE)占用
实时监听串口(带异常处理的推荐写法)
实际使用中建议加 try/except,并支持 Ctrl+C 安全退出:
import serial
import time
<p>try:
ser = serial.Serial('COM3', 115200, timeout=0.1)
print("串口已打开,按 Ctrl+C 停止监听")
while True:
data = ser.readline() # 读到 \n 或超时
if data:
print(data.decode('utf-8', errors='ignore').strip())
time.sleep(0.01)
except serial.SerialException as e:
print(f"串口错误:{e}")
except KeyboardInterrupt:
print("\n已退出")
finally:
if 'ser' in locals() and ser.is_open:
ser.close()











