Windows Batch Script To Backup Data

Computer users who have grown up with advanced Mac and Windows computers may not be aware of it, but once, long ago, all personal computers were controlled using a command-line interface. Yes, that clunky command box on your Windows machine used to be literally the only way most people ever interacted with a computer. Command line interfaces relied heavily on small programs called ‘scripts’, which were collections of operating system commands used to perform common tasks.

Although the graphical user interfaces of today’s PCs are light-years more sophisticated and easy to use than the old command lines, there are still uses for the older method of controlling your computer. One of the most common, and well suited, applications for a command line script is data backup. Command line scripts can be automated to run at any time without any human interaction, and have few limitations. Best of all – they are a  built-in part of the Windows operating system.

Why Command Line Scripts?

Why use a command-line script when there are both commercial and free backup programs out there? Well, command-line scripts have a number of unique advantages. Here are a few of them:

  • Native Commands: What better way to backup data than by using the functions made available through the program which creates the data? Whether this is the operating system itself via a simple file copy command or a database command to produce a restorable binary file, the source program knows best how to back itself up.
  • Ultimate Control: Since a command line script follows a simple step-by-step procedure, you know exactly what is happening and can easily modify the behavior.
  • Fast: Since everything is a native command, nothing is subject to interpretation. Again, you are using commands provided by the program itself, so overhead is kept to a minimum.
  • Powerful: I have yet to see a backup task which cannot be accomplished through a command line script… and I have done some funky stuff. Although you may have to do some research and trial and error if you have really unique needs, typically the built in functions and features of the scripting language you are using are more than sufficient.
  • Free and Flexible: Obviously, a command line script does not cost anything (outside the time to develop it), so you can copy your scripts to any number of machines and systems with little to no time or cost. Compare this to the cost of purchasing licenses for backup software on several servers and/or desktop machines.

A Quick Overview Of The Backup Batch Script

Most people have never learned to use command-line scripting, and it is considered somewhat of a “black art”. However, it is actually a pretty simple thing to learn. Tto demonstrate the power of the command line, I am providing a simple Windows batch script that you can use to backup your  important data. This configurable and customizable script does not require any knowledge (or willingness to learn) of the Windows batch scripting language, but if you decide you do want to learn more about Windows batch scripting, you’ll find this script to be a good starting place.

What the backup script does:

  1. Creates full or daily incremental (see below for a definition) backups of files and folders you specify in a separate configuration text file (see below).
    • When a folder is named, that folder and all sub-folders are backed up.
    • When a file is named, just that file is backed up.
  2. Compresses (zips) the backed up files. After all files to be backed up are copied, they are compressed to save space. 7-Zip is required to be installed on your system for this to work.
  3. Dates the compressed file and moves it to a storage location. After the backup files are compressed, the resulting archive is given a file name according to the current date and then moved to a configured storage location, such as an external drive or network location.
  4. Cleans up after itself. After all tasks are completed, the batch script cleans up all the temporary files it created.

Windows 2000/XP/2003/Vista or newer
7-Zip (it’s free)

Configuration file:
The configuration file is simply a text file which contains files and folders to backup, entered one backup item per line. This file must be named “BackupConfig.txt” and be located in the same folder as the backup script. Here is an example of a BackupConfig.txt file (note, the “#” character on the first line indicates that the line is a comment; comments are always ignored when the script runs):

# Enter file and folder names, one per line.
C:Documents and SettingsJason FaulknerDesktop C:Documents and SettingsJason FaulknerMy DocumentsImportant Files C:ScriptsBackupScript.bat

The example above would backup the Windows user Jason Faulkner’s desktop (and all folders on the desktop), the folder called “Important Files” inside of My Documents (and all folders inside “Important Files”) and the file “BackupScript.bat” inside the C:Scripts directory.

Types of backups:

  • Full backup: A complete copy of all files and folders (including sub-folders) are included in the backup.
  • Incremental backup: When a folder is provided, only files created or modified on the current date are
    backed up. When a file is provided, it is always backed up, regardless of when it was modified.

The Data Backup Windows Batch Script

I want to emphasize this script is very basic, as all it does is create backups by a utilizing a simple file copy. There are some configuration options you can set:

  • The backup storage location where the resulting compressed backup files are stored.
  • The day of the week the full backup is run (any other day would run an incremental backup).
  • Location of where 7-Zip is installed on your computer. The script is automatically set to look in the default location.

If you have any suggestions or feature requests, please comment below. I would really love to do a follow up article to this post which features an updated script based on reader input. If you need instructions on how to “use” this script or set up a scheduled task, take a look at the links below the script source.

Without further ado, here it is:

Note: Since the quotes do not display correctly below (and as a result can mess up the script), I have included a plain text link below the script which you can use to get an accurate source to copy from.


REM BackupScript
REM Version 1.01, Updated: 2008-05-21
REM By Jason Faulkner (articles[-at-]

REM Performs full or incremental backups of folders and files configured by the user.

REM Usage---
REM   > BackupScript


REM ---Configuration Options---

REM Folder location where you want to store the resulting backup archive.
REM This folder must exist. Do not put a '' on the end, this will be added automatically.
REM You can enter a local path, an external drive letter (ex. F:) or a network location (ex. \serverbackups)
SET BackupStorage=C:Backup

REM Which day of the week do you want to perform a full backup on?
REM Enter one of the following: Sun, Mon, Tue, Wed, Thu, Fri, Sat, *
REM Any day of the week other than the one specified below will run an incremental backup.
REM If you enter '*', a full backup will be run every time.
SET FullBackupDay=*

REM Location where 7-Zip is installed on your computer.
REM The default is in a folder, '7-Zip' in your Program Files directory.
SET InstallLocationOf7Zip=%ProgramFiles%7-Zip

REM +-----------------------------------------------------------------------+
REM | Do not change anything below here unless you know what you are doing. |
REM +-----------------------------------------------------------------------+

REM Usage variables.
SET exe7Zip=%InstallLocationOf7Zip%7z.exe
SET dirTempBackup=%TEMP%backup
SET filBackupConfig=BackupConfig.txt

REM Validation.
IF NOT EXIST %filBackupConfig% (
  ECHO No configuration file found, missing: %filBackupConfig%
  GOTO End
IF NOT EXIST "%exe7Zip%" (
  ECHO 7-Zip is not installed in the location: %dir7Zip%
  ECHO Please update the directory where 7-Zip is installed.
  GOTO End

REM Backup variables.
FOR /f "tokens=1,2,3,4 delims=/ " %%a IN ('date /t') DO (
  SET DayOfWeek=%%a
  SET NowDate=%%d-%%b-%%c
  SET FileDate=%%b-%%c-%%d

IF {%FullBackupDay%}=={*} SET FullBackupDay=%DayOfWeek%
IF /i {%FullBackupDay%}=={%DayOfWeek%} (
  SET txtBackup=Full
  SET swXCopy=/e
) ELSE (
  SET txtBackup=Incremental
  SET swXCopy=/s /d:%FileDate%

ECHO Starting to copy files.
IF NOT EXIST "%dirTempBackup%" MKDIR "%dirTempBackup%"
FOR /f "skip=1 tokens=*" %%A IN (%filBackupConfig%) DO (
  SET Current=%%~A
  IF NOT EXIST "!Current!" (
    ECHO ERROR! Not found: !Current!
  ) ELSE (
    ECHO Copying: !Current!
    SET Destination=%dirTempBackup%!Current:~0,1!%%~pnxA
    REM Determine if the entry is a file or directory.
    IF "%%~xA"=="" (
      REM Directory.
      XCOPY "!Current!" "!Destination!" /v /c /i /g /h /q /r /y %swXCopy%
    ) ELSE (
      REM File.
      COPY /v /y "!Current!" "!Destination!"
ECHO Done copying files.


REM If the backup file exists, remove it in favor of the new file.
IF EXIST "%BackupFileDestination%" DEL /f /q "%BackupFileDestination%"

ECHO Compressing backed up files. (New window)
REM Compress files using 7-Zip in a lower priority process.
START "Compressing Backup. DO NOT CLOSE" /belownormal /wait "%exe7Zip%" a -tzip -r -mx5 "%BackupFileDestination%" "%dirTempBackup%"
ECHO Done compressing backed up files.

ECHO Cleaning up.
IF EXIST "%dirTempBackup%" RMDIR /s /q "%dirTempBackup%"

ECHO Finished.


Plain text source is available here:backup

If you need help getting started with implementing this script, here are a couple of links to help you out:

This is the same script I use to backup my computer daily (with a couple of modifications of course), so I know it works very well. I hope you find it useful.


30 thoughts on “Windows Batch Script To Backup Data”

Thomas says:
I get the following output while running the script:

Starting to copy files.
Copying: C:\Users\Thoma\Desktop
Invalid parameter – /d:–
Copying: C:\Users\Thoma\Documents
Invalid parameter – /d:–
Copying: C:\Users\Thoma\Music
Invalid parameter – /d:–
Copying: C:\Users\Thoma\Pictures
Invalid parameter – /d:–
Copying: C:\Users\Thoma\Videos
Invalid parameter – /d:–
Done copying files.

All the file paths I’m attempted to backup have been validated and the backup file is empty.

Sushil Patil says:
when is edit this script.

Staging folder was created and backup folder information show and after that no error showing and no data available on destination folder..

Method invocation failed because [System.Boolean] does not contain a method named ‘Replace’.
At C:\Users\Sushil.Patil\Desktop\BackupScript.ps1:87 char:5
+ $Temp=”^”+$Entry.Replace(“\”,”\\”)
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (:) [], RuntimeException
+ FullyQualifiedErrorId : MethodNotFound

16.07.2019-12:14:52 – INFO: Create Backupdir \\\target\Backup-2019-07-16-13349\
16.07.2019-12:14:52 – INFO: ———————-
16.07.2019-12:14:52 – INFO: Start the Script
16.07.2019-12:14:52 – INFO: Check if there are more than 10 Directories in the Backupdir
16.07.2019-12:14:52 – INFO: Check if there are more than 10 Zip in the Backupdir
16.07.2019-12:14:52 – INFO: Check if BackupDir and Destination exists
16.07.2019-12:14:52 – INFO: Started the Backup
16.07.2019-12:14:52 – INFO: Count all files and create the Top Level Directories
16.07.2019-12:15:12 – INFO: There are 26621 Files with 771.91 MB of Files to copy

Jury Joy Rubi says:
Sorry for my ignorance. I really don’t have any idea about scripting. So just one question. Where will I insert the Data/Folder I want to back-up?
Darrin Wilkinson says:
The files that I want to backup come named differently every day (eg FileA_20160519.csv, then the next day would be FileA_20160520.csv). How can I get the script to backup files using a wildcard (eg FileA_*.csv)?
lvhaow says:
Starting to copy files.

Copying: C:demo01

1 File(s) copied

Copying: C:demo02

1 File(s) copied

Copying: C:ScriptsBackupScript.bat

The system cannot find the path specified.

0 file(s) copied.

Done copying files.

Can you help me? it’s show error: “The system cannot find the path specified.

Location temp backup: C:UsersHAO~1.LUOAppDataLocalTempbackup

Christophe says:
A very nice and usefule dos script. I’ve learned many things about dos scripts.
Thanks a lot !
Mads says:
Can you except some files / directorys?
but except d:\www\cache


Meego92 says:
can you help me by writing a rpogram which do the following:propose an automatic, network-based backup system for our irreplaceable data. The backup should be done on regular basis intervals every Friday at 8 of every week.
Your proposal should be easy to implement, inexpensive, powerful, reliable and documented. Assuming you have a networked windows and Linux machine ready, you should be able to use your project to set up your own automatic backup system in a short time.
sgd says:
I found that script very instresting as i have not done any modification in bat file but i do it in txt file but my all data gets backup in “temp” folder

Please advice

whatdoesitwant says:
Do you plan on fixing this script for windows 7 or porting to powershell? Has anyone found an alternative that works on Windows 7? I’m on a x64 version.

I had fun using this script on Vista. I cannot get Jason Faulkner’s backup script to run on Windows 7 unless I run manually from an elevated prompt in the right directory. When setting the appropriate rights on the bat-file itself and just executing it, the script dies within the first few seconds. Trying every available parameter and option that i could think of, It still dies as a scheduled task in the new Windows 7 task scheduler. That sort of sucks, because I know of no other backup utility that allows me to set different times for full and incremental backups (incremental backups btw also not working on windows 7).

Oscar says:
Hi, Im wondering, how can you make this script to backup only certain type files, for example only files with .doc extensions etc, is there any way? BTW that script is nice!!
ismashkhy says:
Hi, I’m a newbie in scripting, can this be possible?

source folder

destination backup folder

each time the backup is initiated, I only need the added or modified files are the only one that is copied onto the backup destination…

is this possible?, I don’t need any date or what so ever at this time of trying scripting for the first time?…

can anyone give me template script of what I want to do?..

the file to be copied is as it is…copied as original not compressed in zip or rar…

thanks in advance

ken says:
I use this scripts, i think is pretty good. It get the job done.
Now, is there away to Exclude a files or folders?

I have few Vmware folder(BIG size) and few temp folder, which i dont want to back it up.


Hassan Bintook says:
I want to do monthly backup and delete the files

Also the output file should be like xxxxxx_Mar2010.rar


Dawie says:
Loving the script. Got around a problem with incremental backups by changing the below:

SET FileDate=%%b-%%c-%%d
SET FileDate=%%b-%%c-2010

For some reason it does not want to include the year but the above works.

I however cannot use variables like %username% or %appdata% in the “BackupConfig.txt” file.

Any idea why not?

Jason Faulkner says:
The BackupConfig.txt file reads the data in as literal text. It will not process environment variables.
Mike says:
Hi To All,

Im a newbie in netbackup system. Would like to ask some assistance about scripting. We have an existing Replication Manager (RM) that is doing the cloning of disk. and when the cloning is finish we then perform a backup. But we usualy encounter an error. It s because that the cloning is not yet finish and the backup schedule starts already. My boss ask me to create a script that will call to backup the disk after it finish the cloning. I see that we can put the script in the RM system to call it after if finish the cloning. My problem is that scheduling on backup.

we have Daily backup, Weekly backup and every 28 of the month fullbackup.

for daily = 1 week retention
for weekly = 2 weeks retention
for 28th of the month = 1 month retention.

How to create a script that will check if is Monday, Tuesday, Wednesday, Thursday, Friday, Saturday = Daily; Sunday will be Weekly and every 28th of the month is Monthly backup.

Please help me if you have a script that I can use for this setup.

Thank you very much,

email :[email protected]

Scott says:
I have tried to run the script on a 2000 box — verified that the config file is there and after the script runs it terminates immediately indicating that the config file is missing.

Any ideas?


Jason Faulkner says:
Try changing the line which reads:

IF NOT EXIST %filBackupConfig% (


IF NOT EXIST “%filBackupConfig%” (

Frank says:
The script creates an emtpy backup file for me as well with win 2003 server. I found out that it ignores the first line in the config file.

Config file:
c:\test1 <– no backup
c:\test2 <– backup
c:\test3 <– backup

The first line may be empty.
Hope this helps and thanks for your script.

Denis says:
my ‘date’ command returns only date. there is no day of week
I have Windows Server 2003
also tried on Windows 7. same result.
Jason Faulkner says:
Change this:
REM Backup variables.
FOR /f “tokens=1,2,3,4 delims=/ ” %%a IN (‘date /t’) DO (
SET DayOfWeek=%%a
SET NowDate=%%d-%%b-%%c
SET FileDate=%%b-%%c-%%d

To this:
REM Backup variables.
FOR /f “tokens=1,2,3 delims=/ ” %%a IN (‘date /t’) DO (
SET DayOfWeek=%FullBackupDay%
SET NowDate=%%c-%%a-%%b
SET FileDate=%%a-%%b-%%c

This will cause the script to run a full backup every time, but since you do not have the day of week, there is no way to avoid it.

Denis says:
Found a workaround:
Echo.|Command /C Date|Find “Current”
but need to be modified.
dvdljns says:
Can you do a follow up but instead of using 7zip use mkisofs to build spanning iso files cd. using cds to store backups is the way to go.
Mick says:
Thanks for posting this script for us to use! I have been using it since the summer of 2009 and it’s worked great. As a tip for anyone who cares I cloned the script and use multiple instances of it for several different directories that I want to backup. That way, I can schedule them up to run whenever I feel like it. I feel so much better now that I’ve been able to back up my music.
Jennifer says:
still, I can’t imagine something wrong with the following:

# backup files
\\Fs-data\data2\OVI\Safety Management\BRU referentielijst.xls
\\Fs-data\data2\OVI\Safety Management\[INC] Incidenten\[DOS] Dossiers\INC-DOS-0041 hazard log.xls

Jacob Quant says:
Has anyone gotten this to work using UNC paths in BackupConfig.txt? I’m considering modifying so that each remote system is first mounted as a drive letter, but that seems far less than elegant.

**UPDATE:** Actually, it seems my problem was due to an “Access is denied” error that was not being shown by the script. Attempting to run `dir “!Current!”` (where !Current! is the UNC path I was trying to back-up) showed the error.

Clemente Reyes says:
robocopy resolves alot of the UNC issues, the Jason F’s backup script was revised to accommodate robocopy syntax.
Shan says:
Please check your BackupConfig.txt file
the first line is always ignored .
Jennifer says:
Hi Jason, thanks for the tip, but I still get an empty zip-folder. Any other ideas?
Jennifer says:
I can’t seem to get the script working for me. I’m using XP and in the config file I used the following:
# backup files
“\\Fs-data\data2\OVI\Safety Management\BRU referentielijst.xls”
“\\Fs-data\data2\OVI\Safety Management\[INC] Incidenten\[DOS] Dossiers\INC-DOS-0041 hazard log.xls”
It doesn’t matter if I use quotation marks, the files just won’t backup. I can get the file to work when putting in:
\\Fs-data\data2\OVI\Safety Management, however that backups the entire subfolder structure as well, while I only want to backup these 2 files.
Can somebody help me?
Jason Faulkner says:
Try replacing this line:
COPY /v /y “!Current!” “!Destination!”

with this:
XCOPY “!Current!” “!Destination!” /v

SenHu says:
I enjoyed reading your discussion on “Why Command Line Scripts?”. How very appropriate. Have you considered using biterscripting ( ) on windows instead of batch ? It has much better parsing, comparing, catalogging and monitoring capabilities.
HoHum says:
Thank you for this script. It has enhanced my knowledge of batch scripting. I have an issue:

For some strange reason, there must be an existing environmental variable because my backups always include Picasa3 folders; namely: “\CDPrep” and “\Picasa2AlbumsTemp”. The strangeness of this is that the BackupConfig.txt only contains ONE directory to backup. Any thoughts?

Nick says:
I love this script, any plans to make modifications to allow FTP upload for offsite backups?
Jason Faulker says:
I’m doing this in a couple of scripts I have on our servers, it is not very difficult.

Basically you use the FTP command in your script (this is a tool built into Windows) and then pass it a file which has the FTP server name, password and then the subsequent transfer commands each on a single line.

There are plenty of pages out there which explain how to use this, so google help regarding the Windows FTP command and the command line and you can see some examples.

Kyle says:
Hey this script works amazing! I was wondering tho, it does save it as a *.zip file, I was wondering if we can change the compression to “best” and have it create a *.7z file instead, is this possible to tune it up like that?

My output is 1.6gb and I wanted to compress it to make it smaller, and create it in a *.7z. Is that possible? Thanks so much!

Jason Faulkner says:
Kyle says:
Wow thanks! Thank you for sharing this with me and everyone else. =)

I love this script. =D

Thank you.

sune says:
im trying to use that script but only does an empty zip file…

Comments are closed.

Disclaimer: Some pages on this site may include an affiliate link. This does not effect our editorial in any way.

Todays Highlights
How to See Google Search History
how to download photos from google photos