我正在与太阳能逆变器进行一场激烈的战斗,知道吗(INGETEAM 3play)我通过 TCP / IP 连接。
我需要了解如何塑造我的电话,因为我没有我想要的答案,而且我不知道我在等待多少位的答案。 这是我需要做的电话:
我确定 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,但是如何?文档是这样的:
也许被称为 Modicon 的事实是我所缺少的?
总结一下问题:
- 如何塑造我的通话,使其与通话 01 03 00 00 00 06 匹配?
- 为什么当我拨打电话 01 03 00 00 00 06 我得到所有答案(从年到秒)我不应该只得到秒?(认为pdf中的30006代表呼叫本身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']
提前致谢!