4

我正在尝试运行这段代码:

from pymodbus.client.sync import ModbusSerialClient as ModbusClient
import logging

logging.basicConfig()
log = logging.getLogger()
log.setLevel(logging.DEBUG)

client = ModbusClient(method='rtu', baudrate=9600, parity='E', port='/dev/ttyUSB0', timeout=1)
client.connect()

rr = client.read_holding_registers(40000, 7, unit=0x01)
print rr
client.close()

但我只得到这个:

DEBUG:pymodbus.transaction:Running transaction 1
DEBUG:pymodbus.factory:Factory Response[131]
DEBUG:pymodbus.transaction:adding transaction 0
DEBUG:pymodbus.transaction:getting transaction 1
Exception Response(131, 3, IllegalAddress)

另一方面,这个 C 代码(使用 libmodbus)正在工作:

modbus_t *mb;
int16_t hregs[9];
mb = modbus_new_rtu('/dev/ttyUSB0', 9600, 'E', 8, 1);
modbus_set_slave(mb, 1);
modbus_read_registers(mb, 0x40000, 7, hregs)

我究竟做错了什么?

4

2 回答 2

2

我假设您想读取前七个保持寄存器。在这种情况下,要给read_holding_registers函数的地址是0。该函数隐式添加了 40000 的偏移量用于保存寄存器。

因此,尝试将您的读取代码更改为此

rr = client.read_holding_registers(0, 7, unit=0x01)
于 2017-10-31T03:49:08.637 回答
1

异常响应(131, 3, IllegalAddress) 表示:

查询数据字段中包含的值不是从站的允许值。这表明复杂请求的剩余部分的结构存在错误,例如隐含长度不正确。这并不意味着提交存储在寄存器中的数据项具有超出应用程序预期的值,因为 MODBUS 协议不知道任何特定寄存器的任何特定值的重要性。

http://www.simplymodbus.ca/exceptions.htm


[更新]:

您是否尝试使用0x40000or 0x400(在许多情况下作为默认设置)?0x40000(十六进制)与40000(十进制)不同

于 2017-12-10T08:54:43.927 回答