FP_SD_WRITE_LINE

SDカード指定ファイルへの1行書き込み

このFP命令は、s_Inで指定した文字列をd_FullFileNameで指定したSDカード上のファイルに書き込みます。

パラメータ

入力

s_In (STRING)

文字列

d_FullFileName (STRING)

ファイル名

解説

  • SDカードアクセスの注意点もご参照ください。

  • SDメモリアクセス実行中フラグ(sys_bIsSDMemoryAccessActive)は、SDメモリカード命令の実行条件ENTRUEになった後TRUEに変わり、命令の実行が完了するまでTRUEのままです。この間、他のSDメモリーカード命令を実行することはできません。

  • SDメモリアクセス完了フラグ(sys_blsSDMemoryAccessDone)は、命令が実行されるとFALSEに変わり、命令が完了したときTRUEに変わり、そのままTRUEになります。

  • 指定したファイルが存在しない場合、新しいファイルが生成されます。

エラーフラグ

sys_bIsSDMemoryAccessError
  • FALSE: 命令が正常完了したとき

  • TRUE: 命令が異常完了したとき

  • sys_iSDMemoryAccessErrorCodeを使用して、エラーコードを確認します。

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

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

POUヘッダ

POUヘッダには、このプログラムで使用するすべての入力変数と出力変数を宣言します。POUヘッダは全プログラム言語で使用できます。

	VAR
		bStart: BOOL:=FALSE;
			(*activates the instruction*)
		sStringWrite1: STRING[32]:='Test String1';
	END_VAR

POUボディ

変数bStartFALSEからTRUEに変化し、システム変数sys_bIsSDMemoryAccessActive TRUEでないとき、ファンクションが実行されます。

LDボディ

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 8 ;
        NETWORK_BODY
B(B_VARIN,,sStringWrite1,11,4,13,6,);
B(B_CONTACT,,bStart,2,1,4,3,R);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,1,12,3,N);
B(B_VARIN,,'\TestLine.csv',11,5,13,7,);
B(B_F,FP_SD_WRITE_LINE!,,13,2,23,7,,?DEN?Ds_In?Dd_FullFileName?AENO);
L(1,2,2,2);
L(4,2,10,2);
L(12,2,12,4);
L(12,4,13,4);
L(1,0,1,8);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

STボディ

IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
    FP_SD_WRITE_LINE(s_In := sStringWrite1,
                     d_FullFileName := '\TestLine.csv');
END_IF;

複数の行をSDカードに書き込む

POUヘッダ

POUヘッダには、このプログラムで使用するすべての入力変数と出力変数を宣言します。

	VAR
		i: INT:=0;
		asDumpString: ARRAY [0..99] OF STRING[32]:=['1','2','3','4','5','6','7','8',89(''),'z','y','z'];
		dutWriteInfo: FP_SD_WRITE_DUT(wFormat:=11,wMode:=1);
		sDumpString: STRING[3500]:='';
			(*100 * 32 character + separator*)
		bDumpStringArrayToSDCard: BOOL:=FALSE;
		bStoreStringToSDCardFile: BOOL:=FALSE;
	END_VAR

STボディ

if (bDumpStringArrayToSDCard AND not(bStoreStringToSDCardFile)) then
	bDumpStringArrayToSDCard := FALSE;
	(* Convert string array to single string *)
	sDumpString := '';
	for i := 0 to Elem_OfArray1D(asDumpString) -1 do
		sDumpString := CONCAT(sDumpString, asDumpString[i], ','); (* delimiter , OR ; *)
	end_for;
	sDumpString := DELETE(IN := sDumpString, L := 1, P := LEN(sDumpString));
	bStoreStringToSDCardFile := TRUE; (* Enable store to SD card *)
end_if;

if (bStoreStringToSDCardFile AND not(sys_bIsSDMemoryAccessActive)) then
	FP_SD_WRITE_LINE(s_In := sDumpString, d_FullFileName := 'Test.csv');
	bStoreStringToSDCardFile := FALSE;
end_if;

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