当前位置: 首页 > news >正文

Python pyserial库【串口通信】全面讲解

想全面了解DeepSeek的看过来 【包邮】DeepSeek全攻略 人人需要的AI通识课 零基础掌握DeepSeek的实用操作手册指南【限量作者亲笔签名版售完即止】

玩转DeepSeek这本就够了 【自营包邮】DeepSeek实战指南 deepseek从入门到精通实用操作指南现代科技科普读物AI普及知识读物人工智能使用教程中小学读物京东超级618

Python初学者的入门教程 动手学深度学习 PyTorch版 李沐和阿斯顿·张等强强联合之作!机器学习、深度学习、AI领域重磅教程! deepseek机器学习(异步图书出品)

程序员要最先成为AI的主人 AI高手速成 DeepSeek让你工作变轻松 deepseek从入门到精通实战指南人工智能 异步图书出品


pyserial 是 Python 中用于串口通信的标准库,支持跨平台操作(Windows/Linux/macOS)。它提供了简洁的 API 实现与串行设备(如 Arduino、传感器、工业设备等)的数据交互。


核心功能
  1. 串口连接管理
  2. 数据读写(字节/文本)
  3. 参数配置(波特率、数据位等)
  4. 超时与流控制
  5. 端口自动探测

安装
pip install pyserial

核心类与方法
1. 初始化串口
import serialser = serial.Serial(port='COM3',             # Windows 示例# port='/dev/ttyUSB0',   # Linux 示例baudrate=9600,           # 波特率bytesize=serial.EIGHTBITS,  # 数据位(5-8)parity=serial.PARITY_NONE,  # 校验位(NONE, EVEN, ODD)stopbits=serial.STOPBITS_ONE, # 停止位(1, 1.5, 2)timeout=1,               # 读超时(秒)write_timeout=1,         # 写超时(秒)xonxoff=False,           # 软件流控rtscts=False             # 硬件流控
)
2. 基本操作
# 打开串口
if not ser.is_open:ser.open()# 写入数据
ser.write(b'Hello World\r\n')  # 发送字节数据
ser.write("文本数据".encode())  # 发送文本需编码# 读取数据
data = ser.read(size=10)       # 读取10字节
line = ser.readline()          # 读取一行(直到\n)
all_data = ser.read_all()      # 读取缓冲区所有数据# 关闭串口
ser.close()
3. 上下文管理(推荐)
with serial.Serial('COM3', 9600, timeout=1) as ser:ser.write(b'PING')response = ser.readline()print(response.decode())

关键参数详解
参数说明常用值
baudrate波特率9600, 115200
bytesize数据位FIVEBITS, EIGHTBITS
parity校验位PARITY_NONE, PARITY_EVEN
stopbits停止位STOPBITS_ONE, STOPBITS_TWO
timeout读超时None (阻塞), 0 (非阻塞), >0 (等待秒数)
rtscts硬件流控True/False

高级功能
1. 扫描可用端口
from serial.tools import list_portsports = list_ports.comports()
for port in ports:print(f"设备: {port.device}, 描述: {port.description}")
2. 同步 I/O(轮询)
while True:if ser.in_waiting > 0:data = ser.read(ser.in_waiting)print(data.decode(errors='ignore'))
3. 文本模式封装
ser = serial.serial_for_url('COM3', baudrate=115200)
text_wrapper = io.TextIOWrapper(ser, encoding='ascii')
text_wrapper.write("TEXT MODE\r\n")
response = text_wrapper.readline()
4. 错误处理
try:ser.write(b'DATA')
except serial.SerialTimeoutException:print("写超时!")
except serial.SerialException as e:print(f"串口错误: {e}")

典型应用场景
  1. 与 Arduino 通信

    # Arduino 代码: Serial.println(sensorValue);
    with serial.Serial('COM4', 9600, timeout=2) as arduino:arduino.write(b'GET_DATA\n')value = arduino.readline().decode().strip()print(f"传感器值: {value}")
    
  2. 工业 Modbus 协议
    配合 pymodbus 库实现 RTU 通信。

  3. GPS 数据接收

    while True:line = ser.readline().decode('ascii', errors='ignore')if line.startswith('$GPGGA'):  # NMEA 协议print(f"GPS数据: {line}")
    

常见问题解决
  1. 权限问题(Linux)
    将用户加入 dialout 组:

    sudo usermod -aG dialout $USER
    
  2. 端口占用错误
    关闭其他串口调试工具(如 PuTTY)。

  3. 数据乱码
    检查编码一致性:

    data = ser.read().decode('utf-8')  # 或 'ascii', 'latin1'
    
  4. 超时设置

    • timeout=0:非阻塞模式(立即返回)
    • timeout=None:永久阻塞
    • timeout=0.5:等待0.5秒

最佳实践
  1. 使用 with 语句自动管理资源
  2. 始终处理编码/解码错误
  3. 重要操作添加重试机制
  4. 避免在循环中频繁开关串口

参考资源
  • 官方文档
  • GitHub 仓库
  • Arduino-Python 通信示例

通过 pyserial,开发者可以高效实现各类串口设备的控制与数据采集,是嵌入式开发和工业自动化领域的重要工具。

相关文章:

  • vue-28(服务器端渲染(SSR)简介及其优势)
  • 桌面小屏幕实战课程:DesktopScreen 16 HTTP
  • 【Go语言-Day 10】深入指针应用:解锁函数“引用传递”与内存分配的秘密
  • 进阶向:Flask框架详解,从零开始理解Web开发利器
  • 什么是哈希函数(SHA-256)
  • 华为云Flexus+DeepSeek征文|利用华为云一键部署的Dify平台构建高效智能电商客服系统实战
  • 【数据挖掘】贝叶斯分类学习—NaiveBayes
  • Spring Boot 3 多数据源改造全流程:Druid、HikariCP 与 dynamic-datasource 实战总结
  • 23种设计模式——策略模式:像换口红一样切换你的算法
  • Solidity学习 - 函数修改器(modifier)
  • 大事件项目记录10-文章分类接口开发-更新文章分类
  • 太速科技-670-3U VPX PCIe桥扩展3路M.2高速存储模块
  • 莫队算法 —— 将暴力玩出花
  • 配置文件application.yml使用指南
  • Conformal LEC:官方学习教程
  • 大语言模型推理速度优化之模型量化实践
  • 【Elasticsearch】全文检索 组合检索
  • 正交视图三维重建 笔记 2d线到3d线
  • red-black-tree
  • 《Go语言高级编程》玩转RPC