这篇文章主要介绍“python snap7怎么读写PLC”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python snap7怎么读写PLC”文章能帮助大家解决问题。
import snap7 import struct def plc_connection(): PLC_IP = '192.168.10.10' PLC = snap7.client.Client() PLC.connect(PLC_IP, rack=0, slot=1) return PLC PLC = plc_connection()
PLC.read_area()方法从PLC中读取指定区域的数据。
1200表示DB块的编号,90表示DB块内的偏移地址,4表示要读取的字节数。
data2=PLC.db_read(db_number=1200, start=90, size=4) print(data2)
data2是个bytearray(b'\x00\x00\x00\x05'),struct.unpack()方法将读取到的4个字节数据按照大端字节序("!"表示大端字节序)解包为一个整数。解包的结果以元组的形式返回
data3 = struct.unpack('!i', data2) print(data3) #data3 = 5
'!i'
和'!h'
都是Python中struct库中的格式化字符串,用于指定要解析的二进制数据的格式和字节顺序。
其中:
'!'
表示使用网络字节顺序(big-endian)。
'i'
表示要解析的数据类型是4字节的整数,也就是int类型。
'h'
表示要解析的数据类型是2字节的有符号整数,也就是short类型。
因此,'!i'
用于解析4字节的大端整数,'!h'
用于解析2字节的大端有符号整数。
当解析不同类型的数据时,需要使用相应的格式化字符串。在这里,根据PLC中数据类型的不同,可以选择不同的格式化字符串来解析数据。通常需要根据PLC的数据类型和大小来选择正确的格式化字符串,否则解析出来的数据将会是错误的。
已经知道这个要写入的DB块是DINT类型的。要把数字1写进去
a=struct.pack('!i', 1)
a= b'\x00\x00\x00\x01'
PLC.db_write(1200, 90, a)
在这个例子中,1200
表示要写入的DB块的编号,90
表示从该块的偏移地址90处开始写入数据,b'\x00\x00\x00\x01'表示要写入的四个字节的数据。
关于“python snap7怎么读写PLC”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。