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_portsfor port in serial.tools.list_ports.comports(): print(f"{port.device} — {port.description}")
打开串口并收发数据
关键参数:端口号(如 'COM3')、波特率(如 9600)、字节大小、停止位、校验等。最简通信示例如下:
import serial打开串口(超时设为 1 秒,避免阻塞)
ser = serial.Serial('COM3', 9600, timeout=1)
发送字节(注意:必须是 bytes,不是 str)
ser.write(b'hello\r\n')
读取最多 100 字节(返回 bytes)
data = ser.read(100) print(data.decode('utf-8', errors='ignore'))
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 timetry: 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()











