python pyserial优化

时间:2013-09-11 10:34:53

标签: python pyserial

我从串口读取了一些数据。数据打包为9个字符。不需要struct,我知道wat的格式是,但有2个问题: 1)如果我保持端口打开,答案是在事件发生后1-3秒(有一个led面板,我可以看到实时事件和值,这些都是连续的)。我认为它与一些缓冲区有关,只有在满时才会刷新(我强迫在Win32上作为非管理员工作,所以不是很多控制)。读取周期性地执行(200毫秒),因此打开/关闭似乎浪费资源。有没有办法保持端口打开,只是强制缓冲区在读取之前刷新?(来自python!)

2)为了得到这些值,我必须找到一个标记 - 13 - 作为结构的结尾,并且相应地读取(接下来的8个字符或之前的8个)。循环不是最有效的python部分,因此它是一种创建索引,读取数据而不阻塞所有内容的方法吗? (连续读取保持处理器,即使在其他线程中作为非阻塞解决方案)。 如果用于任何用途:

class SeReader(object):
    def __init__(self, tata):
        self.ser = serial.Serial()
        self.ser.baudrate = 2400
        self.ser.port = "COM1"
        self.tata = tata # entry point for main gui notification
        self.val, self.status, self.semn, self.data, self.oldVal = None, None, None, None, None
        self.is_stable, self.on = False, False
        self.stable_count = 0
        self.on = False

    def read(self):
        if not self.on: return False
        self.ser.open()
        data = self.ser.read(18)
        self.ser.close()
        start = -1
        for x in xrange(18):
            if data[x] == '\r':
                start = x + 1
                break
        if start == -1:return True
        self.data = val = data[start:start + 9]
        try:
            self.status = val[0]
            self.val = val[2:8]
            self.semn = val[1]
            self.tata.write_data(self.semn, self.val)
        except Exception as e:
            self.tata.set_cs_unstable()
            self.tata.write_data("> ", "Eroare")
            print(self.val, e)
        if self.val == self.oldVal:
            self.stable_count += 1
        else:
            self.oldVal = self.val
            self.stable_count = 0
        if self.stable_count > 8:self.tata.set_cs_stable()
        else:self.tata.set_cs_unstable()
        return True

self.tata和stuff用于通知主GUI

1 个答案:

答案 0 :(得分:0)

我使用my_serial.inWaiting()的检查来查明是否有任何字节等待读取然后在一个单独的线程中读取它们,然后引发一个附加了接收数据的事件。

一旦我有一个数据块,我可以使用正则表达式(re)搜索给定的开始/结束序列,如果这些块与其他数据混合在一起。