2011-08-05 298 views
0

我正在写一个批处理脚本通过ftp将预定义文件夹的每个子文件夹传输到远程服务器。批处理脚本for循环不工作,只循环一次

一切工作正常,但在for循环中,它只执行一次,只传输一个文件夹,然后打破循环。

我在一堆代码回路

FOR /f "delims= " %%B IN ('DIR "%backup_dir%" /A:D /B') DO (

    here is my code 

) 

当我在使用一些简短的代码回路,如“回声”,它正常运行。但是,当我用ftp命令放入一堆代码时不行。这些ftp代码可以正确运行,但只能运行一次,然后打开循环。

下面

是一段代码在for循环

REM -- Send most recent daily backups offsite 
IF !daily_flag! EQU YES (
    ECHO -- Starting Daily backups for !current_folder! 
    ECHO. 
    CD 1DAYS_OLD\ 

    REM -- Start entries for ftp commands file 
    ECHO user %login% %pass% > %ftp_cmds1% 
    ECHO cd backup/files/!current_folder!/1DAYS_OLD >> %ftp_cmds1% 
    ECHO quit >> %ftp_cmds1% 

    SET go_flag=NO 
    SET /a ftp_cntr=0 
    REM -- Loop to see if offsite backup server is alive 
    :CHECK_FTP1 
    IF !go_flag! EQU NO (
     ECHO %ftp_cmds1% > %ftp_dbg1% 
     ftp -ind -s:%ftp_cmds1% %machine_ip% > %ftp_dbg1% 

     REM -- Check ftp debug file to decide what to do 
     FIND /i "Not connected" %ftp_dbg1% 
     IF !ERRORLEVEL! EQU 0 (
      ECHO *** Unable to connect to offsite backup machine: %machine_ip% at %DATE% 
      ECHO !ftp_cntr! 
      IF !ftp_cntr! GTR 10 (
       ECHO *** Unable to connect to offsite backup machine: %machine_ip% for 10 minutes from %machine% 
       ECHO ----- Start ftp debug file 
       TYPE %ftp_dbg1% 
       ECHO ----- End ftp debug file 
       DEL /f /q %lock_file% 
       DEL /f /q %ftp_cmds1% 
       DEL /f /q %ftp_dbg1% 
       EXIT 2 
      ) ELSE (
       TIMEOUT /t 60 
       SET /a ftp_cntr+= 1 
      ) 
     ) ELSE (
      SET go_flag=YES 
      ECHO Offsite backup machine is alive, proceeding with ftp 
     ) 
     GOTO :CHECK_FTP1 
    ) 

    FIND /i "No such file or directory" %ftp_dbg1% 
    IF !ERRORLEVEL! EQU 0 (
     ECHO * Directory backup/files/!current_folder! does not exist on offsite backup machine. 
     SET go_flag=MKDIR 
    ) 

    REM -- IF %go_flag% == MKDIR create remote directory structure 
    IF !go_flag! EQU MKDIR (
     REM -- Start entries for ftp commands file 
     ECHO user %login% %pass% > %ftp_cmds2% 
     ECHO cd ~/backup/files/ >> %ftp_cmds2% 
     ECHO mkdir !current_folder! >> %ftp_cmds2% 
     ECHO cd !current_folder! >> %ftp_cmds2% 
     ECHO mkdir 1DAYS_OLD >> %ftp_cmds2% 
     ECHO mkdir 2DAYS_OLD >> %ftp_cmds2% 
     ECHO mkdir 3DAYS_OLD >> %ftp_cmds2% 
     ECHO mkdir 4DAYS_OLD >> %ftp_cmds2% 
     ECHO mkdir 5DAYS_OLD >> %ftp_cmds2% 
     ECHO mkdir 6DAYS_OLD >> %ftp_cmds2% 
     ECHO mkdir 7DAYS_OLD >> %ftp_cmds2% 
     ECHO ls -lart >> %ftp_cmds2% 
     ECHO quit >> %ftp_cmds2% 

     ftp -ind -s:%ftp_cmds2% %machine_ip% > %ftp_dbg2% 
     ECHO + Directory structure backup/files/!current_folder! created on offsite backup machine: %machine_ip% 
    ) 

    REM -- FTP to offsite backup machine and begin FTP transfer 
    ECHO user %login% %pass% > %ftp_cmds3% 
    ECHO binary >> %ftp_cmds3% 
    ECHO cd ~/backup/files/!current_folder!/7DAYS_OLD >> %ftp_cmds3% 
    ECHO mdelete * %ftp_cmds3% 
    ECHO cd .. >> %ftp_cmds3% 
    ECHO rmdir 7DAYS_OLD >> %ftp_cmds3% 
    ECHO rename 6DAYS_OLD 7DAYS_OLD >> %ftp_cmds3% 
    ECHO rename 5DAYS_OLD 6DAYS_OLD >> %ftp_cmds3% 
    ECHO rename 4DAYS_OLD 5DAYS_OLD >> %ftp_cmds3% 
    ECHO rename 3DAYS_OLD 4DAYS_OLD >> %ftp_cmds3% 
    ECHO rename 2DAYS_OLD 3DAYS_OLD >> %ftp_cmds3% 
    ECHO rename 1DAYS_OLD 2DAYS_OLD >> %ftp_cmds3% 
    ECHO mkdir 1DAYS_OLD >> %ftp_cmds3% 
    ECHO cd 1DAYS_OLD >> %ftp_cmds3% 
    ECHO mput * >> %ftp_cmds3% 
    ECHO quit >> %ftp_cmds3% 

    ECHO ---- Starting Daily FTP at: %DATE% 
    ftp -ind -s:%ftp_cmds3% %machine_ip% > %ftp_dbg3% 

    REM -- Go up a directory in case you have to next process weekly backups 
    CD.. 
    CD 
    ECHO ---- Finished Daily backups at: %DATE% 
    ECHO. 
    ECHO. 
) 

去任何评论欢迎!

+1

这个'ftp'的东西,它不是批处理文件吗?正如@Andriy指出的, –

+1

,你的代码中可能会有一些BAT文件的调用。分段分解代码(使用'CALL'命令)并一次调试一个步骤,直到找到罪魁祸首。 –

+0

谢谢@PA,这就是我现在所做的。问题位于ftp代码部分。如果没有那部分,循环运行良好,但该部分本身可以正确运行,我不能指出问题。 – yangqi

回答

2

如果您在其中执行任何GOTO,FOR命令将被取消。为了解决这个问题,在FOR命令中调用一个子程序,并在子程序中执行你想要的任何程序(包括goto的)。

+0

正确的答案,但Andriy M在7小时前的评论中提供了相同的答案。 –

+0

对不起,但我没有看到任何提及“FOR命令被取消,如果您在其中执行任何GOTO”(这是问题的原因)既没有“在FOR命令中调用子例程并执行任何进程想要在子程序中“(这是解决问题的方法)。他只是解释了CALL命令的操作。也许我错过了什么? – Aacini

+0

我不应该说“相同的答案”。同样的问题,不同的原因。他指出OP在不使用CALL命令的情况下调用另一个批处理文件,从而终止整个第一批文件(不仅仅是循环)。同样的效果,但不同的原因,但不使用CALL是更直接的问题。它发生在GOTO之前。你们都找到了OP的批处理文件被破坏的两种不同的方式。太糟糕了,你们俩都不可能得到答案。 –