返回SD卡上指定文件的属性
此FP指令返回s_FullFileName所指定SD卡上文件的属性,并将结果存储在d_dutStatus中。
输入
文件名
输出
包含文件属性
在SD存储卡指令的触发器EN变为TRUE后,SD存储访问活动标志(sys_bIsSDMemoryAccessActive)变为TRUE,并保持为TRUE直到执行完成。在此期间,无法执行其他SD存储卡指令。
执行指令时,SD存储访问完成标志(sys_blsSDMemoryAccessDone)为FALSE,指令完成后变为TRUE并保持TRUE。
FALSE:指令完成且没有错误时
TRUE:指令完成但有错误时
使用sys_iSDMemoryAccessErrorCode评估错误代码。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
bStart: BOOL:=FALSE;
(*activates the instruction*)
dutFileStatus: FP_SD_FILE_STATUS_DUT;
END_VAR
当变量bStart从FALSE变为TRUE时,执行此函数。
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 4 ;
NETWORK_BODY
B(B_F,FP_SD_GET_FILE_STATUS!,,20,0,33,4,,?DEN?Ds_FullFileName?AENO?Cd_dutStatus);
B(B_CONTACT,,bStart,3,1,5,3,R);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,11,1,13,3,N);
B(B_VARIN,,'\Test\TestString1.csv',18,2,20,4,);
B(B_VAROUT,,dutFileStatus,33,2,35,4,);
L(1,2,3,2);
L(13,2,20,2);
L(5,2,11,2);
L(1,0,1,4);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
FP_SD_GET_FILE_STATUS(s_FullFileName := '\Test\TestString1.csv', d_dutStatus => dutFileStatus);
END_IF;