FP_DATA_SEARCH

データサーチ

このFP命令は、実行条件ENTRUEのとき、s2_Starts3_Endで指定される範囲内で、s1で指定される値をサーチします。

パラメータ

入力

s1 (INT, DINT, UINT, UDINT, REAL, LREAL)

サーチするデータ

s2_Start (INT, DINT, UINT, UDINT, REAL, LREAL)

サーチ範囲の先頭

s3_End (INT, DINT, UINT, UDINT, REAL, LREAL)

サーチ範囲の最後

出力

d1_Count (DINT)

サーチ一致個数(サーチ命令用ワーク1)

d2_Pos (DINT)

最初に一致したデータの相対位置(最初の位置は0)

解説

  • s2_Start£s3_Endであることを確認してください。

  • 変数s1s2_Starts3_Endは同じデータ型を使用してください。

  • サーチできるデータの最大数は30000です。

エラーフラグ

sys_bIsOperationErrorHold (TRUEになり、TRUEを保持)
  • インデックス修飾時にエリアを超えたとき

  • s2_Start>s3_Endのとき

  • s2_Starts3_Endが別々のデータエリアに存在するとき。

sys_bIsOperationErrorNonHold (1回のスキャンに対してTRUE)
  • インデックス修飾時にエリアを超えたとき

  • s2_Start>s3_Endのとき

  • s2_Starts3_Endが別々のデータエリアに存在するとき。

POUヘッダ

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

POUボディ

変数bStartTRUEにセットされると、このファンクションが実行されます。

LDボディ

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

STボディ

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;

最終修正日: 2022-10-18このページに関するフィードバックお問い合わせ窓口