SD 카드상의 파일 또는 디렉토리 복사
이 FP 명령은 s3_Format에서 지정한 파라미터에 따라 s1_FullFileNameSource에서 지정한 SD 카드의 파일을 s2_FullFileNameDestination에서 지정한 파일에 복사합니다.
입력
소스 파일 및 디렉토리
대상 파일 및 디렉토리
파일 처리 및 형식:
비트 0:
0: 파일이 있는 경우 덮어쓰기
1: 파일이 있는 경우 비정상적인 종료
비트 1–15: 시스템에 예약됨
SD 카드 메모리 사전 주의사항도 참조해 주십시오.
SD 메모리 카드 명령의 트리거 EN이 TRUE로 전환된 후 SD 메모리 액세스 활성 플래그(sys_bIsSDMemoryAccessActive)는 TRUE로 전환되고 실행이 완료될 때까지 TRUE로 유지됩니다. 이 시간 동안에는 다른 SD 메모리 카드 명령을 실행할 수 없습니다.
디렉토리가 s1_FullFileNameSource에 지정되고 파일이 s2_FullFileNameDestination에 지정되면 에러 3 "파일/디렉토리 이름 에러"가 발생합니다.
디렉토리가 s1_FullFileNameSource에서 지정되면 이 디렉토리에 있는 모든 파일은 s2_FullFileNameDestination에서 지정한 디렉토리에 복사됩니다. 하위 디렉토리는 복사되지 않습니다.
쓰기 보호된 파일을 덮어 쓸 수 없습니다.
s1_FullFileNameSource와 s2_FullFileNameDestination이 동일한 경우, s3_Format 값에 관계없이 에러가 발생합니다.
파일이 s1_FullFileNameSource에서 지정되고 디렉토리가 s2_FullFileNameDestination에서 지정되면 파일은 디렉토리에 복사됩니다.
이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다.모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.
VAR
bStart: BOOL:=FALSE;
(*activates the instruction*)
END_VAR
변수 bStart가 FALSE에서 TRUE로 변경되고 시스템 변수 sys_bIsSDMemoryAccessActive가 TRUE가 아니면 함수가 실행됩니다. 이것은 'Test' 디렉토리에 있는 'TestString1.csv' 파일을 동일한 디렉토리에 있는 'TestString2.csv' 파일에 복사합니다.
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,,0,21,4,23,6,);
B(B_CONTACT,,bStart,3,1,5,3,R);
B(B_VARIN,,'\Test\TestString1.csv',21,2,23,4,);
B(B_VARIN,,'\Test\TestString2.csv',21,3,23,5,);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,11,1,13,3,N);
B(B_F,FP_SD_COPY_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_COPY_FILE('\Test\TestString1.csv', '\Test\TestString2.csv');
END_IF;