FP_SD_WRITE_LINE

Scrivere una linea da un file specificato su una SD memory card

Questa istruzione FP scrive la stringa specificata da s_In nel file specificato da d_FullFileName sulla SD memory card.

Parametri

Ingresso

s_In (STRING)

Stringa

d_FullFileName (STRING)

Nome del file

Note

  • Fare riferimento anche alle precauzioni per l’accesso alla SD card.

  • Il flag accesso memoria SD attivo (sys_bIsSDMemoryAccessActive) passa a TRUE dopo che il trigger EN dell’istruzione di accesso alla memoria SD è passata a TRUE e resta TRUE fino al completamento dell’esecuzione. Durante questo periodo non è possibile eseguire altre istruzioni di accesso alla memoria SD.

  • Il flag accesso memoria SD eseguito (sys_blsSDMemoryAccessDone) è FALSE quando l’istruzione viene eseguita e passa a TRUE e resta TRUE quando l’istruzione è stata completata.

  • Se il file specificato non esiste, verrà creato un nuovo file.

Flag di errore

sys_bIsSDMemoryAccessError
  • FALSE: quando l’istruzione è stata completata senza errori

  • TRUE: quando l’istruzione è stata completata con un errore

  • Utilizzare sys_iSDMemoryAccessErrorCode per valutare il codice di errore.

sys_bIsOperationErrorHold (passa a TRUE e resta TRUE)
  • se l'area specificata utilizzando il registro indice eccede il limite.

sys_bIsOperationErrorNonHold (passa a TRUE per una scansione)
  • se l'area specificata utilizzando il registro indice eccede il limite.

Esempio

Intestazione del POU

Tutte le variabili di ingresso e uscita utilizzate per programmare questa funzione sono state dichiarate nell'intestazione del POU. La stessa intestazione del POU è utilizzata per tutti i linguaggi di programmazione.

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

Corpo del POU

Quando la variabile bStart passa da FALSE a TRUE e la variabile di sistema sys_bIsSDMemoryAccessActive non è TRUE, la funzione viene svolta.

Corpo 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

Corpo ST

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

Esempio scrittura di linee multiple su una SD card

Intestazione del POU

Tutte le variabili di ingresso e uscita utilizzate per programmare questa funzione sono state dichiarate nell'intestazione del 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

Corpo 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;

L'ultima revisione: 2024-03-07Feedback su questa paginaPanasonic hotline