如何将一个DB块的部分数据复制到另一个DB块里

如题,而且一次只传一个数据,数据并不连续,数据量很多,不要用MOVE

问题补充:
sfc20是整体移动的,而且数据是连续的。我想用指针,只是每次都得到的结果都不对,希望能有个很会用指针的大师写个例程,谢谢

最佳答案

FC1 VOID 
title=这个功能可以实现从任意DB号的任意首地址开始的num个DINT数复制到从任意DB号开始的任意首地址开始的num个DINT处。
VAR_INPUT
DBNum1:INT
DBNum2:INT
#Num :INT
change_addr1 :INT
change_addr2:INT
VAR_TEMP
Source:ANY
Target:ANY
END_VAR
L P##Source
LAR1
L W#16#1007
T W[AR1,P#0.0]
L ##Num 
T W[AR1,P#2.0]
L #DBNum1 
T W[AR1,P#4.0]
L #change_addr1
SLD 3
OD DW#16#84000000
T D[AR1,P#6.0]
L P##Target 
LAR1
L W#16#1007
T W[AR1,P#0.0]
L ##Num 
T W[AR1,P#2.0]
L #DBNum2
T W[AR1,P#4.0]
L #change_addr2
SLD 3
OD DW#16#84000000
T D[AR1,P#6.0]
CALL "BLKMOV"
SRCBLK :=#Source
RET_VAL:=#ErrState
DSTBLK :=#Target 
如果
DBNum1:INT :=1
DBNum2:INT :=2
#Num :INT :=4
change_addr1 :INT:=2
change_addr2:INT:=4
就可以实现把 DB1.DBX2.0 4 DINT数复制到DB2.DBX4.0 4 DINT中

提问者对于答案的评价:
谢谢~

原创文章,作者:more0621,如若转载,请注明出处:https://www.zhaoplc.com/plc227664.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2018年12月1日
下一篇 2018年12月1日

相关推荐