Как читать данные в Raspberry Pi с помощью modbus-tk?
Итак, я делаю проект, в котором хочу, чтобы мой Raspberry Pi 4 обменивался данными через Modbus. Я купил щит, чтобы включить связь RS485 с Pi, и я модифицировал демонстрационный код (Software/Test Codes/MODBUS/rtumaster.py) и использовал симулятор подчиненного устройства на своем компьютере для тестирования.
Я обращаюсь к вам, потому что я застрял при попытке прочитать данные с моего ведомого устройства. Команда, кажется, проходит нормально (или, возможно, лучше сказать, симулятор подчиненного устройства не жалуется), но я не знаю, как передать данные в мою программу. Я пробовал что-то вроде этого:
read = logger.info(master.execute(1, cst.READ_INPUT_REGISTERS, 5, 1))
А затем пытаюсь распечатать это значение для проверки, но оно просто возвращает "Нет" вместо моего значения. Любая помощь приветствуется.
Текущий код:
## To install dependencies:
## sudo pip3 install modbus-tk
##################################################################################################
import serial
import fcntl
import os
import struct
import termios
import array
#import modbus lib
import modbus_tk
import modbus_tk.defines as cst
import modbus_tk.modbus as modbus
#import modbus_tk.modbus_rtu as modbus_rtu
from modbus_tk import modbus_rtu
# RS485 ioctls define
TIOCGRS485 = 0x542E
TIOCSRS485 = 0x542F
SER_RS485_ENABLED = 0b00000001
SER_RS485_RTS_ON_SEND = 0b00000010
SER_RS485_RTS_AFTER_SEND = 0b00000100
SER_RS485_RX_DURING_TX = 0b00010000
# rs 485 port
ser1 = serial.Serial("/dev/ttySC0",19200)
ser2 = serial.Serial("/dev/ttySC1",9600)
def rs485_enable():
buf = array.array('i', [0] * 8) # flags, delaytx, delayrx, padding
#enable 485 chanel 1
fcntl.ioctl(ser1, TIOCGRS485, buf)
buf[0] |= SER_RS485_ENABLED|SER_RS485_RTS_AFTER_SEND
buf[1] = 0
buf[2] = 0
fcntl.ioctl(ser1, TIOCSRS485, buf)
#enable 485 chanel 2
fcntl.ioctl(ser2, TIOCGRS485, buf)
buf[0] |= SER_RS485_ENABLED|SER_RS485_RTS_AFTER_SEND
buf[1] = 0
buf[2] = 0
fcntl.ioctl(ser2, TIOCSRS485, buf)
#end of rs485_enable():
if __name__ == '__main__':
logger = modbus_tk.utils.create_logger("console")
rs485_enable()
#set modbus master
master = modbus_rtu.RtuMaster(
serial.Serial(port= '/dev/ttySC0',
baudrate=9600,
bytesize=8,
parity='N',
stopbits=1,
xonxoff=0)
)
master.set_timeout(5.0)
master.set_verbose(True)
logger.info("connected")
read = logger.info(master.execute(1, cst.READ_INPUT_REGISTERS, 5, 1))
print("Value is: ", read)