通过modbus_tk模块包实现各功能modbus的应用场景

作为master端,读取机器人寄存器数据、往机器人寄存器中写入数据。

作为master端的应用主要的方法exec(slave=1, function_code=READ_HOLDING_REGISTERS, starting_address=0, quantity_of_x=0, output_value=0, data_format="", expected_length=-1)

参数说明:@slave=1 : identifier of the slave. from 1 to 247. @function_code=READ_HOLDING_REGISTERS:功能码@starting_address=100:寄存器的开始地址@quantity_of_x=3:寄存器/线圈的数量@output_value:一个整数或可迭代的值:1/[1,1,1,0,0,1]/xrange(12)@data_format:对接收的数据进行格式化@expected_length:(没对这个设置过)例子

example 1:读取寄存器数据

读取寄存器数据 解释一波:
接收后返回的值,是元组,元组中值的个数由quantity_of_x决定。
quantity_of_x最大值为127。

import modbus_tk.modbus_tcp as mtimport modbus_tk.defines as md# 通过MODBUS方式获取机器人心跳# 需要有机器人的继电器地址、端口号,接收的数据格式内容。def heart_status(): # 远程连接到slave端(从) ip = "127.0.0.1" port = 502 master = mt.TcpMaster(ip, port) master.set_timeout(5.0) while True: # 获取想要的寄存器的数据 status = master.execute(slave=1, function_code=md.READ_HOLDING_REGISTERS, starting_address=0, quantity_of_x=5) print("status== ", status) # 结果是一个元组,里面有5个值,由quantity_of_x决定的if __name__ == "__main__": heart_status()

example 2:向寄存器写入数据

向寄存器写入数据 解释一波:
starting_address: 向哪个寄存器写入数据的地址;多写的话就是开始地址了;
output_value: 为想要写入的值;
data_format: 根据实际情况去更改。

def robot_on(): ip = "127.0.0.1" port = 502 # 向第9个寄线器的写入值,这里写入1 master = mt.TcpMaster(modbus_ip, modbus_port) # WRITE_SINGLE_REGISTER写入的是单个寄存器,所以值是一个,也可以写成[1] master.execute(1, md.WRITE_SINGLE_REGISTER, starting_address=9, output_value=1, data_format='BBBBB') if __name__ == '__main__': robot_on()数据格式化

data_format的参考unpcak中的格式字符串内容