SD 카드의 파일 이동
이 FP 명령은 s1_FullFileNameSource에서 지정한 파일을 s2_FullFileNameDestination에서 지정한 파일로 이동합니다.
입력
소스 파일 및 디렉토리
대상 파일 및 디렉토리
파일 전송 형식:
비트 0:
0: 파일이 있는 경우 덮어쓰기
1: 파일이 있는 경우 비정상적인 종료
비트 1–15: 시스템에 예약됨
s2_FullFileNameDestination에서 지정한 디렉토리가 없으면 에러 3 "파일/디렉토리 이름 에러"가 발생합니다.
여유 용량이 부족하면 에러 9 "SD 카드가 가득 참"이 발생합니다.
디렉토리가 s1_FullFileNameSource에서 지정되면 이 디렉토리에 있는 모든 파일은 s2_FullFileNameDestination에서 지정한 디렉토리로 이동합니다.
하위 디렉토리는 이동되지 않습니다.
쓰기 보호된 파일이 이동되면 해당 속성이 유지됩니다.
SD 카드의 여유 공간은 이동할 파일보다 커야 합니다.
파일이 s1_FullFileNameSource에서 지정되고 디렉토리가 s2_FullFileNameDestination에서 지정되면 파일은 디렉토리로 이동합니다.
이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다. 모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.
VAR
bStart: BOOL:=FALSE;
(*activates the instruction*)
END_VAR
변수 bStart가 FALSE에서 TRUE로 변경되고 시스템 변수 sys_bIsSDMemoryAccessActive가 TRUE가 아니면 함수가 실행됩니다. 'TestString1.csv' 파일이 SD 카드의 루트 디렉토리에서 'Test' 디렉토리로 이동합니다.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
B(B_VARIN,,'\TestString1.csv',21,2,23,4,);
B(B_VARIN,,'\Test\TestString1.csv',21,3,23,5,);
B(B_VARIN,,0,21,4,23,6,);
B(B_CONTACT,,bStart,3,1,5,3,R);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,11,1,13,3,N);
B(B_F,FP_SD_MOVE_FILE!,,23,0,37,6,,?DEN?Ds1_FullFileNameSource?Ds2_FullFileNameDestination?Ds3_Format?AENO);
L(1,2,3,2);
L(5,2,11,2);
L(13,2,23,2);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
FP_SD_MOVE_FILE('\TestString1.csv', '\Test\TestString1.csv');
END_IF;