Я нахожусь в серьезной битве с солнечным инвертором. (INGETEAM 3play) Я подключен по TCP / IP.
Мне нужно понять, как сформировать мой вызов, потому что у меня нет ответа, который я хочу, а также я не знаю, сколько битов я жду ответа. Вот вызов, который мне нужно сделать:
![Call and answer](https://i.stack.imgur.com/Ty6D4.png)
Я уверен, что 01 - это ID 03 означает Регистр хранения, поэтому как мне сформировать отдых (00 00 00 06) ?? Это код:
FORMAT = ('%(asctime)-15s %(threadName)-15s '
'%(levelname)-8s %(module)-15s:%(lineno)-8s %(message)s')
logging.basicConfig(format=FORMAT)
log = logging.getLogger('pymodbus.protocol')
log.setLevel(logging.DEBUG)
variables = [0,6,12,18,24,30,36,70,72,74,76,78,342,344]
data = client.read_holding_registers(0, 2, unit=1)
decoder = BinaryPayloadDecoder.fromRegisters(data.registers, Endian.Big)
eastron = round(decoder.decode_32bit_float(), 3)
print (eastron)
Я знаю, что мне нужно играть с client.read_holding_registers, но как? Документация выглядит так: ![enter image description here](https://i.stack.imgur.com/zA5e2.png)
Может быть, я скучаю по факту, который называется Modicon?
Подводя итоги по вопросам:
- Как настроить мой вызов так, чтобы он соответствовал вызову 01 03 00 00 00 06?
- Почему, когда я выполняю вызов 01 03 00 00 00 06, я получаю все ответы (год к секундам) я не должен просто получить секунды? (думая, что 30006 в pdf обозначает сам вызов 03 00 00 00 06)
- Как я могу зарегистрировать отладку, которую я получаю при выполнении вызова? я делаю это в малине, и я не уверен, что смогу увидеть вызов, как я делаю на jupyter
пример
DEBUG:pymodbus.transaction:Current transaction state - TRANSACTION_COMPLETE
DEBUG:pymodbus.transaction:Running transaction 6
DEBUG:pymodbus.transaction:SEND: 0x1 0x3 0x0 0x0 0x0 0x2 0xc4 0xb
DEBUG:pymodbus.framer.rtu_framer:Changing state to IDLE - Last Frame End - 1580425865.276049, Current Time stamp - 1580425955.463177
DEBUG:pymodbus.client.sync:New Transaction state 'SENDING'
DEBUG:pymodbus.transaction:Changing transaction state from 'SENDING' to 'WAITING FOR REPLY'
DEBUG:pymodbus.transaction:Changing transaction state from 'WAITING FOR REPLY' to 'PROCESSING REPLY'
DEBUG:pymodbus.transaction:RECV: 0x1 0x3 0x4 0x41 0x60 0x0 0x0 0xee 0x11
DEBUG:pymodbus.framer.rtu_framer:Getting Frame - 0x3 0x4 0x41 0x60 0x0 0x0
DEBUG:pymodbus.factory:Factory Response[ReadHoldingRegistersResponse: 3]
DEBUG:pymodbus.framer.rtu_framer:Frame advanced, resetting header!!
DEBUG:pymodbus.transaction:Adding transaction 1
DEBUG:pymodbus.transaction:Getting transaction 1
DEBUG:pymodbus.transaction:Changing transaction state from 'PROCESSING REPLY' to 'TRANSACTION_COMPLETE'
DEBUG:pymodbus.payload:[16736, 0]
DEBUG:pymodbus.payload:[b'A`', b'\x00\x00']
Заранее спасибо!