FP_SD_MOVE_FILE

Mover un archivo a una tarjeta SD

Estas instrucciones mueven el archivo especificado por s1_FullFileNameSource al archivo especificado por s2_FullFileNameDestination.

Parámetros

Entrada

s1_FullFileNameSource (STRING)

Archivo y directorio fuente

s2_FullFileNameDestination (STRING)

Archivo y directorio de destino

s3_Format (WORD)

Formato de transferencia de archivos:

Bit 0:

  • 0: Sobreescribir si ya existe el archivo

  • 1: Finalización con error si ya existe el archivo

Bit 1–15: Reservado para el sistema

Observaciones

  • La bandera "acceso a memoria SD en proceso" (sys_bIsSDMemoryAccessActive) pasa a TRUE después de la que la entrada de trigger EN de las instrucciones de la tarjeta SD haya pasado a TRUE y continúe en TRUE hasta concluir la ejecución. En este intervalo, no se pueden ejecutar otras instrucciones de la tarjeta SD.
  • Si el directorio especificado por s2_FullFileNameDestination no existe, se produce un error 3 "Error de nombre de archivo/directorio".

  • Si no hay suficiente capacidad libre, se produce un error 9 "Tarjeta SD llena".

  • Si se ha especificado un directorio para s1_FullFileNameSource, y un archivo para s2_FullFileNameDestination, se produce el error 3 "Error de nombre de archivo/directorio".
  • Si se ha especificado un directorio por s1_FullFileNameSource, todos los archivos de ese directorio se moverán al directorio especificado por s2_FullFileNameDestination.

  • Los subdirectorios no se mueven.

  • Los archivos con protección de escritura movidos conservarán su estado.

  • La capacidad libre de la tarjeta SD debe ser mayor que los archivos a mover.

  • Si se ha especificado un archivo por s1_FullFileNameSource y un directorio por s2_FullFileNameDestination, el archivo se mueve al directorio.

Banderas de error

sys_bIsOperationErrorHold (pasa a TRUE y permanece TRUE)
  • si el área especificada utilizando el modificador índice supera el límite.
sys_bIsOperationErrorNonHold (pasa a TRUE para un ciclo de scan)
  • si el área especificada utilizando el modificador índice supera el límite.

Ejemplo

Cabecera de la POU

Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.

	VAR
		bStart: BOOL:=FALSE;
			(*activates the instruction*)
	END_VAR

Cuerpo de la POU

Cuando la variable bStart pasa de FALSE a TRUE, y la variable del sistema sys_bIsSDMemoryAccessActive no es TRUE, se ejecuta la función. Mueve el archivo 'TestString1.csv' del directorio raíz de la tarjeta SD al directorio 'Test'.

Cuerpo LD

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

Cuerpo en ST

IF DF(bStart)AND not sys_bIsSDMemoryAccessActive then
    FP_SD_MOVE_FILE('\TestString1.csv', '\Test\TestString1.csv');
END_IF;

Modificado el: 2024-03-07Comentarios sobre esta páginaLínea directa de Panasonic