pyserial 中的 Serial.available() 等价物是什么?

2023-07-23Python开发问题
13

本文介绍了pyserial 中的 Serial.available() 等价物是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

当我尝试在 Arduino 上读取多行串行数据时,我使用以下成语:

When I am trying to read multiple lines of serial data on an Arduino, I use the following idiom:

String message = "";
while (Serial.available()){
    message = message + serial.read()
}

在 Arduino C 中,Serial.available() 返回可从串行缓冲区读取的字节数(参见 文档).python中Serial.available()的等价物是什么?

In Arduino C, Serial.available() returns the number of bytes available to be read from the serial buffer (See Docs). What is the equivalent of Serial.available() in python?

例如,如果我需要读取多行串行数据,我希望使用以下代码:

For example, if I need to read multiple lines of serial data I would expect to ues the following code:

import serial
ser = serial.Serial('/dev/ttyACM0', 9600, timeout=0.050)
...
while ser.available():
    print ser.readline()

推荐答案

属性 Serial.in_waiting 返回接收缓冲区中的字节数".

The property Serial.in_waiting returns "the number of bytes in the receive buffer".

这似乎相当于 Serial.available() 的描述:已经到达并存储在串行接收缓冲区中的字节数."

This seems to be the equivalent of Serial.available()'s description: "the number of bytes ... that's already arrived and stored in the serial receive buffer."

试试:

import serial
ser = serial.Serial('/dev/ttyACM0', 9600, timeout=0.050)
...
while ser.in_waiting:  # Or: while ser.inWaiting():
    print ser.readline()

对于 pyserial 3.0 之前的版本,使用 .inWaiting().要确定您的 pyserial 版本,请执行以下操作:

For versions prior to pyserial 3.0, use .inWaiting(). To determine your pyserial version, do this:

import serial
print(serial.__version__)

这篇关于pyserial 中的 Serial.available() 等价物是什么?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

在xarray中按单个维度的多个坐标分组
groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)...
2024-08-22 Python开发问题
15

Pandas中的GROUP BY AND SUM不丢失列
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)...
2024-08-22 Python开发问题
17

pandas 有从特定日期开始的按月分组的方式吗?
Is there a way of group by month in Pandas starting at specific day number?( pandas 有从特定日期开始的按月分组的方式吗?)...
2024-08-22 Python开发问题
10

GROUP BY+新列+基于条件的前一行抓取值
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)...
2024-08-22 Python开发问题
18

PANDA中的Groupby算法和插值算法
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)...
2024-08-22 Python开发问题
11

PANAS-基于列对行进行分组,并将NaN替换为非空值
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)...
2024-08-22 Python开发问题
10