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.
Ingresso
Stringa
Nome del file
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.
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.
se l'area specificata utilizzando il registro indice eccede il limite.
se l'area specificata utilizzando il registro indice eccede il limite.
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
Quando la variabile bStart passa da FALSE a TRUE e la variabile di sistema sys_bIsSDMemoryAccessActive non è TRUE, la funzione viene svolta.
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
IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
FP_SD_WRITE_LINE(s_In := sStringWrite1,
d_FullFileName := '\TestLine.csv');
END_IF;
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
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;