master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=new)new有要求数值类型吗
时间: 2023-12-13 16:03:38 浏览: 36
是的,new需要是一个整数类型的值。在Modbus协议中,写入多个寄存器的值必须是整数类型。如果new不是整数类型,可以先将其转换为整数类型,然后再进行写入操作。例如,如果new是一个字符串类型的值,可以使用int()函数将其转换为整数类型,如下所示:
```python
new = int(new)
master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=new)
```
这将把new转换为整数类型,并将其写入从机1的起始地址为0的多个寄存器中。
相关问题
red = master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9)[0] # 这里可以修改需要读取的功能码 print(red) new = (red / 2) print(new) master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=new)object of type 'float' has no len()
这个错误是因为 `red` 变量的类型是 `float`,而不能像 `list` 一样使用 `len()` 方法。你需要将 `red` 转换成一个整型值,然后再使用 `len()` 方法。例如:
```
red = int(master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9)[0]) # 将 float 值转换成整型
print(red)
new = red / 2
print(new)
master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=new)
```
注意,如果你使用 Python 2.x 版本,则使用 `/` 运算符对两个整数进行除法运算,结果将会是一个整数。如果你希望得到一个浮点数结果,需要将其中一个整数强制转换成浮点数,例如:
```
red = int(master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9)[0]) # 将 float 值转换成整型
print(red)
new = float(red) / 2 # 将其中一个整数强制转换成浮点数
print(new)
master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=new)
```
这样就能够避免出现 `TypeError: object of type 'float' has no len()` 的错误了。
import serial,time,struct import modbus_tk.defines as cst from modbus_tk import modbus_rtu # from modbus_tk.utils import create_master_string def main(): # 打开两个串口 com1 = serial.Serial(port='com2', baudrate=38400, bytesize=8, parity='N', stopbits=1) com2 = serial.Serial(port='com3', baudrate=38400, bytesize=8, parity='N', stopbits=1) # 创建Modbus RTU主机(master) master = modbus_rtu.RtuMaster(com1) master.set_timeout(1.0) master.set_verbose(True) # time.sleep(2) # 读取保持寄存器数据 red = master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9) print(red) red1 = master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9)[0] # 这里可以修改需要读取的功能码 print(red1) new = int(red1 * 0.98) print(new) master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=[new]) time.sleep(0.5) red = master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9) print(red,0) # 读取输入寄存器数据 input_regs = master.execute(1, cst.READ_INPUT_REGISTERS, 0, 9) print(input_regs, 1) # 读取输入线圈数据 input_bits = master.execute(1, cst.READ_COILS, 0, 9) print(input_bits, 2) # 读取输出线圈数据 output_bits = master.execute(1, cst.READ_DISCRETE_INPUTS, 0, 9) print(output_bits, 3)。现在将所有读取数据打包为Modbus RTU消息并写入com2串口。要求打包的Modbus RTU消息格式要跟 master = modbus_rtu.RtuMaster(com1)一样
好的,我理解你的要求了。你可以使用modbus_tk.utils模块中的create_master_string函数来将Modbus RTU消息打包。下面是一个示例代码,可以将上面的读取数据和写入数据的代码整合在一起,并将结果写入com2串口:
```
import serial
import time
import struct
import modbus_tk.defines as cst
from modbus_tk import modbus_rtu
from modbus_tk.utils import create_master_string
def main():
# 打开两个串口
com1 = serial.Serial(port='com2', baudrate=38400, bytesize=8, parity='N', stopbits=1)
com2 = serial.Serial(port='com3', baudrate=38400, bytesize=8, parity='N', stopbits=1)
# 创建Modbus RTU主机(master)
master = modbus_rtu.RtuMaster(com1)
master.set_timeout(1.0)
master.set_verbose(True)
# 读取保持寄存器数据
red = master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9)
print(red)
red1 = red[0] # 这里可以修改需要读取的功能码
print(red1)
new = int(red1 * 0.98)
print(new)
master.execute(1, function_code=cst.WRITE_MULTIPLE_REGISTERS, starting_address=0, output_value=[new])
time.sleep(0.5)
red = master.execute(1, cst.READ_HOLDING_REGISTERS, 0, 9)
print(red, 0)
# 读取输入寄存器数据
input_regs = master.execute(1, cst.READ_INPUT_REGISTERS, 0, 9)
print(input_regs, 1)
# 读取输入线圈数据
input_bits = master.execute(1, cst.READ_COILS, 0, 9)
print(input_bits, 2)
# 读取输出线圈数据
output_bits = master.execute(1, cst.READ_DISCRETE_INPUTS, 0, 9)
print(output_bits, 3)
# 将所有读取数据打包为Modbus RTU消息并写入com2串口
msg = create_master_string(slave=1, function_code=cst.READ_HOLDING_REGISTERS, starting_address=0, quantity_of_x=9, output_value=red)
com2.write(msg)
msg = create_master_string(slave=1, function_code=cst.READ_INPUT_REGISTERS, starting_address=0, quantity_of_x=9, output_value=input_regs)
com2.write(msg)
msg = create_master_string(slave=1, function_code=cst.READ_COILS, starting_address=0, quantity_of_x=9, output_value=input_bits)
com2.write(msg)
msg = create_master_string(slave=1, function_code=cst.READ_DISCRETE_INPUTS, starting_address=0, quantity_of_x=9, output_value=output_bits)
com2.write(msg)
if __name__ == '__main__':
main()
```
请注意,create_master_string函数的参数与execute函数的参数非常相似,但有一些差异。具体来说,create_master_string函数需要传递slave参数,它表示Modbus从站的地址。此外,它的function_code参数表示要执行的Modbus功能码,而不是execute函数中的function_code参数。最后,output_value参数是一个可选参数,表示要写入的数据,如果是读操作,则可以忽略它。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)