Сравните и замените файлы, используя командный файл

2

Используя пакетный файл, вы можете сделать fc folder1\* folder2\*

Теперь я хотел бы расширить это для поддержки подпапок (при условии, что это еще не сделано, idk) и дополнительно автоматически перемещать отсутствующие файлы из folder2в folder1, но я действительно не знаю как.

TagsIsAKeyword
источник
1
Не ясно, какова ваша конечная цель, но xcopy /d /s folder2\* folder1\ убедитесь, что она folder1содержит любые новые или обновленные файлы folder2. Неясно, почему вы хотите запустить fc, так как это подразумевает ручное решение о файлах, а не пакетную операцию.
AFH
так `xcopy / d / s folder2 * folder1` должен сделать свое дело? Я думал, что вы захватите содержимое fc, а затем запустите на них другой пакетный файл, вот что.
ТегиIsAKeyword

Ответы:

1

Вам должно быть хорошо использовать встроенную Robocopyкоманду Windows, а не XCOPYили FCкоторая является более надежной для выполнения вашей задачи, чем, как вы описываете, вы делаете это. Это простой и понятный метод с использованием собственных ROBOCOPY команд Windows из пакетного сценария или командной строки. Вы также можете проверить файл журнала на предмет точных файлов, которые впоследствии были рекурсивно скопированы в место назначения.

Если вы создаете что - то новое, что было бы лучше использовать Robocopyвместо , XCOPYкак XCOPYэто устаревшая команда предназначена для заменить Robocopy специально на Microsoft , как в Windows Vista (и более новых операционных системы) , я считаю.


Robocopy Script

(См. Примечание сценария ниже для опций, которые я использовал в этом примере, а также обязательно измените пути переменных sourcedir и targettdir, где вам нужны эти наборы. Обязательно проведите тестирование из тестового местоположения, а также просто тщательно и подтвердите себя перед использованием для производственных целей)

@ECHO ON
SETLOCAL
SET SourceDir=C:\SourcePath
SET TargetDir=C:\TargetPath
SET LogFile=C:\LogPath\Logfile.txt
ROBOCOPY "%SourcePath%" "%TargetDir%" *.* /PURGE /S /NP /R:5 /LOG+:%Log% /TS /FP
GOTO EOF

Сценарий Примечание

Я использовал эти опции в своем примере, но ниже смотрите, как увидеть все опции, чтобы в дальнейшем удовлетворить ваши частичные потребности.

/S         :: copy Subdirectories, but not empty ones.
/PURGE     :: delete dest files/dirs that no longer exist in source.
/NP        :: No Progress - don't display % copied.
/R:n       :: number of Retries on failed copies: default 1 million.
/LOG+:file :: output status to LOG file (append to existing log).
/TS        :: include source file Time Stamps in the output.
/FP        :: include Full Pathname of files in the output.

ДАЛЬНЕЙШИЕ ИССЛЕДОВАНИЯ И ДЕТАЛИ

В командной строке Windows введите, Robocopy /?а затем нажмитеEnter

C:\Users\User>robocopy /?

-------------------------------------------------------------------------------
   ROBOCOPY     ::     Robust File Copy for Windows

-------------------------------------------------------------------------------

  Started : Fri Dec 18 02:29:48 2015

              Usage :: ROBOCOPY source destination [file [file]...] [options]

             source :: Source Directory (drive:\path or \\server\share\path).
        destination :: Destination Dir  (drive:\path or \\server\share\path).
               file :: File(s) to copy  (names/wildcards: default is "*.*").

::
:: Copy options :
::
                 /S :: copy Subdirectories, but not empty ones.
                 /E :: copy subdirectories, including Empty ones.
             /LEV:n :: only copy the top n LEVels of the source directory tree.

                 /Z :: copy files in restartable mode.
                 /B :: copy files in Backup mode.
                /ZB :: use restartable mode; if access denied use Backup mode.
            /EFSRAW :: copy all encrypted files in EFS RAW mode.

  /COPY:copyflag[s] :: what to COPY for files (default is /COPY:DAT).
                       (copyflags : D=Data, A=Attributes, T=Timestamps).
                       (S=Security=NTFS ACLs, O=Owner info, U=aUditing info).

           /DCOPY:T :: COPY Directory Timestamps.

               /SEC :: copy files with SECurity (equivalent to /COPY:DATS).
           /COPYALL :: COPY ALL file info (equivalent to /COPY:DATSOU).
            /NOCOPY :: COPY NO file info (useful with /PURGE).

            /SECFIX :: FIX file SECurity on all files, even skipped files.
            /TIMFIX :: FIX file TIMes on all files, even skipped files.

             /PURGE :: delete dest files/dirs that no longer exist in source.
               /MIR :: MIRror a directory tree (equivalent to /E plus /PURGE).

               /MOV :: MOVe files (delete from source after copying).
              /MOVE :: MOVE files AND dirs (delete from source after copying).

     /A+:[RASHCNET] :: add the given Attributes to copied files.
     /A-:[RASHCNET] :: remove the given Attributes from copied files.

            /CREATE :: CREATE directory tree and zero-length files only.
               /FAT :: create destination files using 8.3 FAT file names only.
               /256 :: turn off very long path (> 256 characters) support.

             /MON:n :: MONitor source; run again when more than n changes seen.
             /MOT:m :: MOnitor source; run again in m minutes Time, if changed.

      /RH:hhmm-hhmm :: Run Hours - times when new copies may be started.
                /PF :: check run hours on a Per File (not per pass) basis.

             /IPG:n :: Inter-Packet Gap (ms), to free bandwidth on slow lines.

                 /SL:: copy symbolic links versus the target.
::
:: File Selection Options :
::
                 /A :: copy only files with the Archive attribute set.
                 /M :: copy only files with the Archive attribute and reset it.
    /IA:[RASHCNETO] :: Include only files with any of the given Attributes set.
    /XA:[RASHCNETO] :: eXclude files with any of the given Attributes set.

 /XF file [file]... :: eXclude Files matching given names/paths/wildcards.
 /XD dirs [dirs]... :: eXclude Directories matching given names/paths.

                /XC :: eXclude Changed files.
                /XN :: eXclude Newer files.
                /XO :: eXclude Older files.
                /XX :: eXclude eXtra files and directories.
                /XL :: eXclude Lonely files and directories.
                /IS :: Include Same files.
                /IT :: Include Tweaked files.

             /MAX:n :: MAXimum file size - exclude files bigger than n bytes.
             /MIN:n :: MINimum file size - exclude files smaller than n bytes.

          /MAXAGE:n :: MAXimum file AGE - exclude files older than n days/date.
          /MINAGE:n :: MINimum file AGE - exclude files newer than n days/date.
          /MAXLAD:n :: MAXimum Last Access Date - exclude files unused since n.
          /MINLAD:n :: MINimum Last Access Date - exclude files used since n.
                       (If n < 1900 then n = n days, else n = YYYYMMDD date).

                /XJ :: eXclude Junction points. (normally included by default).

               /FFT :: assume FAT File Times (2-second granularity).
               /DST :: compensate for one-hour DST time differences.

               /XJD :: eXclude Junction points for Directories.
               /XJF :: eXclude Junction points for Files.

::
:: Retry Options :
::
               /R:n :: number of Retries on failed copies: default 1 million.
               /W:n :: Wait time between retries: default is 30 seconds.

               /REG :: Save /R:n and /W:n in the Registry as default settings.

               /TBD :: wait for sharenames To Be Defined (retry error 67).

::
:: Logging Options :
::
                 /L :: List only - don't copy, timestamp or delete any files.
                 /X :: report all eXtra files, not just those selected.
                 /V :: produce Verbose output, showing skipped files.
                /TS :: include source file Time Stamps in the output.
                /FP :: include Full Pathname of files in the output.
             /BYTES :: Print sizes as bytes.

                /NS :: No Size - don't log file sizes.
                /NC :: No Class - don't log file classes.
               /NFL :: No File List - don't log file names.
               /NDL :: No Directory List - don't log directory names.

                /NP :: No Progress - don't display % copied.
               /ETA :: show Estimated Time of Arrival of copied files.

          /LOG:file :: output status to LOG file (overwrite existing log).
         /LOG+:file :: output status to LOG file (append to existing log).

       /UNILOG:file :: output status to LOG file as UNICODE (overwrite existing
log).
      /UNILOG+:file :: output status to LOG file as UNICODE (append to existing
log).

               /TEE :: output to console window, as well as the log file.

               /NJH :: No Job Header.
               /NJS :: No Job Summary.

           /UNICODE :: output status as UNICODE.

::
:: Job Options :
::
       /JOB:jobname :: take parameters from the named JOB file.
      /SAVE:jobname :: SAVE parameters to the named job file
              /QUIT :: QUIT after processing command line (to view parameters).

              /NOSD :: NO Source Directory is specified.
              /NODD :: NO Destination Directory is specified.
                /IF :: Include the following Files.
Сок Pimp IT
источник
Спасибо за это: я не пользуюсь Windows в наши дни, и я всегда думал, что robocopyэто стороннее программное обеспечение.
AFH
@AFH Звучит так, будто это третье лицо, но это не так, оно встроено в Windows. Я использую его для определенных задач, и он так же интегрирован с Windows, как xopy и copy. Для дальнейшего использования xopy и copy все еще используются, но для гораздо более простых задач. Например, я использую копию только для принудительного копирования отдельных файлов.
взаимосвязанная