Как сформировать ЗВОНОК в PYMODBUS (Modicon?)

Я участвую в серьезной битве с солнечным инвертором, я знаю (INGETEAM 3play), что я подключен по TCP / IP.

Мне нужно понять, как сформировать свой звонок, потому что у меня нет ответа, который я хочу, а также я не знаю, сколько бит я жду ответа. Вот вызов, который мне нужно сделать:

Я уверен, что 01 - это идентификатор. 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, но как? Документация выглядит так:

Может быть, мне не хватает того, что называется Modicon?

Подытоживая вопросы:

  1. Как сформировать мой звонок, чтобы он соответствовал звонку 01 03 00 00 00 06?
  2. Почему, когда я звоню 01 03 00 00 00 06, я получаю все ответы (от года до секунд), разве я не должен получать только секунды? (думая, что 30006 в PDF означает сам звонок 03 00 00 00 06)
  3. Как я могу зарегистрировать ОТЛАДКУ, полученную при звонке? Я делаю это в малине, и я не уверен, что смогу увидеть звонок, как на 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']

Заранее спасибо!

1 ответ

Решение
  1. Как сформировать мой звонок, чтобы он соответствовал звонку 01 03 00 00 00 06?

Расшифровывая это, мы получаем:

01 - ID объекта; 1 байт; 01
03 - Код функции; 1 байт; 0x03 = чтение регистров временного хранения
00 00 - начальный адрес; 2 байта (с прямым порядком байтов); Адрес 0
00 06 - количество регистров; 2 байта (с прямым порядком байтов); Длина 6

Это означает, что приведенный выше запрос к модулю ID 1 на "чтение регистров временного хранения" (3), начиная с регистра 0, возвращает шесть регистров.

Чтобы дублировать это с помощью pymodbus, вы должны использовать client.read_holding_registers(0, 6, unit=1).

  1. Почему, когда я звоню 01 03 00 00 00 06, я получаю все ответы (от года до секунд), разве я не должен получать только секунды? (думая, что 30006 в PDF означает сам звонок 03 00 00 00 06)

Как отмечалось выше, запрос касается шести регистров (так что это включает полный рабочий день).

  1. Как я могу зарегистрировать ОТЛАДКУ, полученную при звонке? Я делаю это в малине, и я не уверен, что смогу увидеть звонок, как на jupyter

Из вашего примера похоже, что вы уже генерируете отладочную информацию. Поскольку Modbus является стандартом, вам обычно не нужно смотреть на отправляемые / получаемые байты при использовании достойной библиотеки, которая справится с этим за вас.

Другие вопросы по тегам