Я могу подключиться к счетчику энергии (Бодрейт 300!), И лог-файл с 228 строками появляется медленно.
line = ser.readline(eol='!')
print line
Если я использую приведенный выше код, отображаются полные лог-файлы.И если я анализирую отдельно сохраненные лог-файлы с помощью match, он сортирует правильные значения в sqlite.Таким образом, обе «части» работают раздельно.
Но мой сценарий не способен передать выходные данные для его анализа.Это не выдает ошибку, только что были даны 0 значений.
Что я пропустил?Сначала я подумал, что сценарий предназначен для быстрого медленного ввода (занимает более минуты), но сценарий ждет достаточно долго, прежде чем его завершить.
#!/usr/bin/env python
# -*- coding: iso-8859-1 -*-
import serial
import time
import re
import sqlite3
ser = serial.Serial()
ser.baudrate = 300
ser.port = '/dev/ttyUSB0'
ser.timeout = 20
ser.parity = serial.PARITY_EVEN
ser.stopbits = serial.STOPBITS_ONE
ser.bytesize = serial.SEVENBITS
ser.open()
ser.isOpen()
#initiating logfile-output with /?!
time.sleep(2)
ser.write("/?!")
#time.sleep(0.001)
ser.write("\r\n")
time.sleep(2)
connection = sqlite3.connect('/var/www/zaehler/test1.db')
cursor = connection.cursor()
extrakt = []
#line = ser.readline(eol='!')
#print line-would work
for line in ser.readline(eol='!'):
match = re.search(r'(0\.0\.0|0\.9\.1|0\.9\.2|1\.6\.1|1\.8\.1)\(([0-9\.]+)', line)
if match:
version,value = match.groups()
extrakt.append(value)
cursor.execute('INSERT INTO energielog (sernr, time, date, peak, kwh) values (?, ?, ?, ?, ?)', extrakt)
connection.commit()
ser.close()
cursor.close()
connection.close()
Я пытался без успеха:
ser.readline(eol='!') = z
for line in z:
match..
выдает ошибку SyntaxError: невозможно назначить вызов функции