データサーチ
このFP命令は、実行条件ENがTRUEのとき、s2_Startとs3_Endで指定される範囲内で、s1で指定される値をサーチします。
入力
サーチするデータ
サーチ範囲の先頭
サーチ範囲の最後
出力
サーチ一致個数(サーチ命令用ワーク1)
最初に一致したデータの相対位置(最初の位置は0)
s2_Start£s3_Endであることを確認してください。
変数s1、s2_Start、s3_Endは同じデータ型を使用してください。
サーチできるデータの最大数は30000です。
インデックス修飾時にエリアを超えたとき
s2_Start>s3_Endのとき
s2_Startとs3_Endが別々のデータエリアに存在するとき。
インデックス修飾時にエリアを超えたとき
s2_Start>s3_Endのとき
s2_Startとs3_Endが別々のデータエリアに存在するとき。
POUヘッダには、このプログラムで使用するすべての入力変数と出力変数を宣言します。POUヘッダは全プログラム言語で使用できます。
VAR
bStart: BOOL:=FALSE;
(*activates the fuction*)
diSearch_value: DINT:=16#20;
(*specifies the value to
search for*)
adiDataField: ARRAY [0..3] OF DINT:=[16#101,16#20,16#2A04,16#20];
(*2 matches for 16#20
data_array[2] = 1st match*)
diNumber_matches: DINT:=0;
diPosition1_match: DINT:=0;
END_VAR
変数bStartがTRUEにセットされると、このファンクションが実行されます。
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 7 ;
NETWORK_BODY
B(B_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,diSearch_value,11,3,13,5,);
B(B_VARIN,,adiDataField[0],11,4,13,6,);
B(B_VARIN,,adiDataField[3],11,5,13,7,);
B(B_F,FP_DATA_SEARCH!,,13,1,23,7,,?DEN?D@'s1'?Ds2_Start?Ds3_End?AENO?Cd1_Count?Cd2_Pos);
B(B_VAROUT,,diNumber_matches,23,3,25,5,);
B(B_VAROUT,,diPosition1_match,23,4,25,6,);
L(8,3,13,3);
L(1,3,6,3);
L(1,0,1,7);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF bStart then
FP_DATA_SEARCH(s1 := diSearch_value,
s2_Start := adiDataField[0],
s3_End := adiDataField[3],
d1_Count => diNumber_matches,
d2_Pos => diPosition1_match);
END_IF;