Bernard Aybouts - Blog - Miltonmarketing.com

Approx. read time: 16.5 min.

Post: What is a Batch file?

What is a Batch file? Aย batch fileย is a kind ofย script fileย inย DOS,ย OS/2ย andย Microsoft Windows. It consists of a series ofย commandsย to be executed by theย command-line interpreter, stored in aย plain textย file. A batch file may contain any command the interpreter accepts interactively and use constructs that enable conditional branching and looping within the batch file, such asย IF,ย FOR, andย GOTOย labels. The term “batch” is fromย batch processing, meaning “non-interactive execution”, though a batch file may not process aย batchย of multiple data.

Similar toย Job Control Languageย (JCL) and other systems on mainframe and minicomputer systems, batch files were added to ease the work required for certain regular tasks by allowing the user to set up a script to automate them. When a batch file is run, theย shellprogram (usuallyย COMMAND.COMย orย cmd.exe) reads the file and executes its commands, normally line-by-line.ย Unix-likeย operating systems, such asย Linux, have a similar, but more flexible, type of file called aย shell script.

Theย filename extensionย .batย is used in DOS and Windows.ย Windows NTย and OS/2 also addedย .cmd. Batch files for other environments may have different extensions, e.g.,ย .btmย inย 4DOS,ย 4OS2ย andย 4NTย related shells.

The detailed handling of batch files has changed. Some of the detail in this article applies to all batch files, while other details apply only to certain versions.

Variants

DOS

In DOS, a batch file can be started from theย command-line interfaceย by typing its name, followed by any required parameters and pressing theย โ†ต Enterย key. When DOS loads, the fileย AUTOEXEC.BAT, when present, is automatically executed, so any commands that need to be run to set up the DOS environment may be placed in this file. Computer users would have the AUTOEXEC.BAT file set up the system date and time, initialize the DOS environment, load any resident programs or device drivers, or initialize network connections and assignments.

A .bat file name extension identifies a file containing commands that are executed by the command interpreterย COMMAND.COMย line by line, as if it were a list of commands entered manually, with some extra batch-file-specific commands for basic programming functionality, including aย GOTOย command for changing flow of line execution.

Early Windows

Microsoft Windowsย was introduced in 1985 as aย graphical user interface-based (GUI) overlay on text-basedย operating systemsย and was designed to run on DOS. In order to start it, theย WINย command was used, which could be added to the end of theย AUTOEXEC.BATย file to allow automatic loading of Windows. In the earlier versions, one could run a .bat type file from Windows in the MS-DOS Prompt.ย Windows 3.1xย and earlier, as well asย Windows 9xย invoked COMMAND.COM to run batch files.

OS/2

Theย IBMย OS/2ย operating system supported DOS-style batch files. It also included a version ofย REXX, a more advanced batch-fileย scripting language. IBM and Microsoft started developing this system, but during the construction of it broke up after a dispute; as a result of this, IBM referred to their DOS-like console shell without mention of Microsoft, naming it just DOS, although this seemingly made no difference with regard to the way batch files worked from COMMAND.COM.

OS/2’s batch file interpreter also supports an EXTPROC command. This passes the batch file to the program named on the EXTPROC file as a data file. The named program can be a script file; this is similar to theย #!ย mechanism.

Windows NT

Unlikeย Windows 98ย and earlier, theย Windows NTย family of operating systems does not depend on MS-DOS. Windows NT introduced an enhanced 32-bit command interpreter (cmd.exe) that could execute scripts with either the .CMD or .BAT extension. Cmd.exe added additional commands, and implemented existing ones in a slightly different way, so that the same batch file (with different extension) might work differently with cmd.exe and COMMAND.COM. In most cases, operation is identical if the few unsupported commands are not used. Cmd.exe’s extensions to COMMAND.COM can be disabled for compatibility.

Microsoft released a version of cmd.exe for Windows 9x and ME called WIN95CMD to allow users of older versions of Windows to use certain cmd.exe-style batch files.

As of Windows 8, cmd.exe is the normal command interpreter for batch files; the older COMMAND.COM can be run as well in 32-bit versions of Windows able to run 16-bit programs.

Filename extensions

.bat
The first filename extension used byย Microsoftย for batch files. This extension runs with DOS and all versions of Windows, under COMMAND.COM or cmd.exe, despite the different ways the two command interpreters execute batch files.
.cmd
Used for batch files inย Windows NTย family and sent to cmd.exe for interpretation. COMMAND.COM does not recognize this file name extension, so cmd.exe scripts are not executed in the wrong Windows environment by mistake. In addition,ย append,ย dpath,ย ftype,ย set,ย path,ย assocย andย promptย commands, when executed from a .bat file, alter the value of theย errorlevelย variable only upon an error, whereas from within a .cmd file, they would affect errorlevel even when returning without an error.ย It is also used by IBM’s OS/2 for batch files.
.btm
The extension used byย 4DOS,ย 4OS2,ย 4NTย andย Take Command. These scripts are faster, especially with longer ones, as the script is loaded entirely ready for execution, rather than line-by-line.

Batch file parameters

COMMAND.COM and cmd.exe support that a number of special variables (%0,ย %1ย throughย %9) in order to refer to the path and name of theย batch jobย and the first nine calling parameters from within the batch job, see alsoย SHIFT. Non-existent parameters are replaced by a zero-length string. They can be used similar toย environment variables, but are not stored in the environment. Microsoft and IBM refer to these variables asย replacement parametersย orย replaceable parameters, whereas Digital Research, Novell and Caldera established the termย replacement variablesย for them. JP Software calls themย batch file parameters.

Examples

This example batch file displaysย Hello World!, prompts and waits for the user to press a key, and then terminates. (Note: It does not matter if commands are lowercase or uppercase unless working with variables)


@ECHO OFF
ECHO Hello World!
PAUSE

To execute the file, it must be saved with the extension .bat (or .cmd for Windows NT-type operating systems) in plain text format, typically created by using a text editor such asย Microsoft Notepadย or aย word processorย in text mode.

When executed, the following is displayed:

Hello World!
Press any key to continue . . .

Explanation

The interpreter executes each line in turn, starting with the first. Theย @ย symbol at the start of any line prevents the prompt from displaying that command as it is executed. The commandย ECHO OFFย turns off the prompt permanently, or until it is turned on again. The combinedย @ECHO OFFย is often as here the first line of a batch file, preventing any commands from displaying, itself included. Then the next line is executed and theย ECHO Hello World!ย command outputsย Hello World!. The next line is executed and theย PAUSEย command displaysย Press any key to continue . . .ย and pauses the script’s execution. After a key is pressed, the script terminates, as there are no more commands. In Windows, if the script is executed from an already runningย command promptย window, the window remains open at the prompt as in MS-DOS; otherwise, the window closes on termination.

Limitations and exceptions

Null values in variables

Variable expansions are substituted textually into the command, and thus variables which contain nothing simply disappear from the syntax, and variables which contain spaces turn into multiple tokens. This can lead to syntax errors or bugs.

For example, ifย %foo% is empty, this statement:

IF %foo%==bar ECHO Equal

parses as the erroneous construct:

IF ==bar ECHO Equal

Similarly, ifย %foo%ย containsย abc def, then a different syntax error results:

IF abc def==bar ECHO Equal

The usual way to prevent this problem is to surround variable expansions in quotes so that an empty variable expands into the valid expressionย IF ""=="bar"ย instead of the invalidย IF ==bar. The text that is being compared to the variable must also be enclosed in quotes, because the quotes are not special delimiting syntax; these characters represent themselves.

IF "%foo%"=="bar" ECHO Equal

The delayedย !VARIABLE! expansion available in Windows 2000 and later may be used to avoid these syntactical errors. In this case, null or multi-word variables do not fail syntactically because the value is expanded after the IF command is parsed:

IF !foo!==bar ECHO Equal

Another difference in Windows 2000 or higher is that an empty variable (undefined) is not substituted. As described in previous examples, previous batch interpreter behaviour would have resulted in an empty string. Example:

C:\>set MyVar=
C:\>echo %MyVar%
%MyVar%

C:\>if "%MyVar%"=="" (echo MyVar is not defined) else (echo MyVar is %MyVar%)
MyVar is %MyVar%

Batch interpreters prior to Windows 2000 would have displayed resultย MyVar is not defined.

Quotation marks and spaces in passed strings

  • For some commands, spaces are treated as delimiters in commands, unless those spaces are enclosed by quotation marks. A single quotation mark (“) is not included as part of the string. However, an escaped quotation mark (“””) can be part of the string.
  • For other commands, spaces are not treated as delimiters and do not need quotation marks. If quotes are included they become part of the string.

This can cause conflicts where a string contains quotation marks, and is to be inserted into another line of text that must also be enclosed in quotation marks:

C:\>set foo="this string is enclosed in quotation marks"

C:\>echo "test 1 %foo%"
"test 1 "this string is enclosed in quotation marks""

C:\>eventcreate /T Warning /ID 1 /L System /SO "Source" /D "Example: %foo%"
ERROR: Invalid Argument/Option - 'string'.
Type "EVENTCREATE /?" for usage.

On Windows 2000 and later, the solution is to replace each occurrence of a quote character within a value by a series of three quote characters:

C:\>set foo="this string is enclosed in quotes"

C:\>set foo=%foo:"="""%

C:\>echo "test 1 %foo%"
"test 1 """this string is enclosed in quotes""""

C:\>eventcreate /T Warning /ID 1 /L System /SO "Source" /D "Example: %foo%"
SUCCESS: A 'Warning' type event is created in the 'Source' log/source.

Escaped characters in strings

Some characters, such as pipe (|) characters, have special meaning to the command line. They cannot be printed as text using theย ECHOย command unless escaped using the caret ^ symbol:

C:\>Echo foo | bar
'bar' is not recognized as an internal or external command,
operable program or batch file.

C:\>Echo foo ^| bar
foo | bar

However, escaping does not work as expected when inserting the escaped character into an environment variable. The variable ends up containing a live pipe command when merely echoed. It is necessary to escape both the caret itself and the escaped character for the character display as text in the variable:

C:\>set foo=bar | baz
'baz' is not recognized as an internal or external command,
operable program or batch file.

C:\>set foo=bar ^| baz
C:\>echo %foo%
'baz' is not recognized as an internal or external command,
operable program or batch file.

C:\>set foo=bar ^^^| baz
C:\>echo %foo%
bar | baz

The delayedย !VARIABLE!ย expansion available withย CMD /V:ONย or withย SETLOCAL ENABLEDELAYEDEXPANSIONย in Windows 2000 and later may be used to show special characters stored in environment variables because the variable value is expanded after the command was parsed:

C:\>cmd /V:ON
Microsoft Windows [Version 6.1.7601]
Copyright (c) 2009 Microsoft Corporation. All rights reserved.

C:\>set foo=bar ^| baz
C:\>echo !foo!
bar | baz

Sleep or scripted delay

Until the TIMEOUT command was introduced with Windows Vista, there was no easy way to implement a timed pause, as the PAUSE command halts script activity indefinitely until any key is pressed.

Many workarounds were possible,ย but generally only worked in some environments: Theย CHOICEย command was not available in older DOS versions,ย PINGย was only available if TCP/IP was installed, and so on. No solution was available from Microsoft, but a number of small utility programs, could be installed from other sources. A commercial example would be the 1988 Norton Utilitiesย Batch Enhancerย (BE) command, whereย BE DELAY 18ย would wait for 1 second, or the free 94-byte WAIT.COMย whereย WAIT 5ย would wait for 5 seconds, then return control to the script. Most such programs are 16-bit .COM files, so are incompatible with 64-bit Windows.

Text output with stripped CR/LF

Normally, all printed text automatically has the control characters forย carriage returnย (CR) andย line feedย (LF) appended to the end of each line.

  • batchtest.bat
    @echo foo
    @echo bar
    
    C:\>batchtest.bat
    foo
    bar
    

It does not matter if the two echo commands share the same command line; the CR/LF codes are inserted to break the output onto separate lines:

C:\>@echo Message 1&@echo Message 2
Message 1
Message 2

A trick discovered with Windows 2000 and later is to use the special prompt for input to output text without CR/LF trailing the text. In this example, the CR/LF does not follow Message 1, but does follow Line 2 and Line 3:

  • batchtest2.bat
    @echo off
    set /p ="Message 1"<nul
    echo Message 2
    echo Message 3
    
    C:\>batchtest2.bat
    Message 1Message 2
    Message 3
    

This can be used to output data to a text file without CR/LF appended to the end:

C:\>set /p ="Message 1"<nul >data.txt
C:\>set /p ="Message 2"<nul >>data.txt
C:\>set /p ="Message 3"<nul >>data.txt
C:\>type data.txt
Message 1Message 2Message 3

However, there is no way to inject this stripped CR/LF prompt output directly into an environment variable.

Setting a UNC working directory from a shortcut

It is not possible to have a command prompt that uses aย UNC pathย as the current working directory; e.g.ย \\server\share\directory\

The command prompt requires the use of drive letters to assign a working directory, which makes running complex batch files stored on a server UNC share more difficult. While a batch file can be run from a UNC file path, the working directory default isย C:\Windows\System32\.

In Windows 2000 and later, a workaround is to use theย PUSHDย andย POPDย command with command extensions.

If not enabled by default, command extensions can be temporarily enabled using theย /E:ONย switch for the command interpreter.

So to run a batch file on a UNC share, assign a temporary drive letter to the UNC share, and use the UNC share as the working directory of the batch file, a Windows shortcut can be constructed that looks like this:

  • Target:ย %COMSPEC%ย /E:ON /Cย "PUSHD """\\SERVER\SHARE\DIR1\DIR2\""" & BATCHFILE.BAT & POPD"

The working directory attribute of this shortcut is ignored.

This also solves a problem related toย User Account Controlย (UAC) on Windows Vista and newer. When an administrator is logged on and UAC is enabled, and they try to run a batch file as administrator from a network drive letter, using the right-click file context menu, the operation will unexpectedly fail. This is because the elevated UAC privileged account context does not have network drive letter assignments, and it is not possible to assign drive letters for the elevated context via the Explorer shell or logon scripts. However, by creating a shortcut to the batch file using the above PUSHD / POPD construct, and using the shortcut to run the batch file as administrator, the temporary drive letter will be created and removed in the elevated account context, and the batch file will function correctly.

The following syntax does correctly expand to the path of the current batch script.

%~dp0

UNC default paths are turned off by default as they used to crash older programs.

The Dword registry valueย DisableUNCCheckย atย HKEY_CURRENT_USER\Software\Microsoft\Command Processorย allows the default directory to be UNC.ย CDย command will refuse to change but placing a UNC path in Default Directory in a shortcut to Cmd or by using the Start command.ย start "" /d \\127.0.0.1\C$ "cmd /k"ย (C$ย share is for administrators).

Character set

Batch files use an OEM character set, as defined by the computer, e.g.ย Code page 437. The non-ASCII parts of these are incompatible with theย Unicodeย orย Windows character sets otherwise used in Windows so care needs to be taken.ย Non-English file names work only if entered through a DOS character set compatible editor. File names with characters outside this set won’t work in batch files.

To get output in Unicode into file pipes from an internal command such asย dir, one can use theย cmd /Uย command. For example,ย cmd /U /C dir > files.txtย creates a file containing a directory listing with correct Windows characters, in theย UTF-16LE encoding.

Batch viruses and malware

As with any other programming language, batch files can be used maliciously. Simpleย trojansย andย fork bombsย are easily created, and batch files can do a form ofย DNS poisoningย by modifying theย hosts file. Batch viruses are possible, and can also spread themselves viaย USB flash drivesย by using Windows’ย Autorunย capability.

The following command in a batch file will delete all the data in the current directory (folder) – without first asking for confirmation:

del /Q *.*

These three commands are a simpleย fork bombย that will continually replicate itself to deplete available system resources, slowing down or crashing the system:

:TOP
 start "" %0
 goto TOP

Other Windows scripting languages

The cmd.exe command processor that interprets .cmd files is supported in all 32- and 64-bit versions of Windows up to at least Windows 10. COMMAND.EXE, which interprets .BAT files, was supported in all 16- and 32-bit versions up to at least Windows 10.

There are other, later and more powerful, scripting languages available for Windows. However, these require the scripting language interpreter to be installed before they can be used:

  • KiXtartย (.kix)ย โ€” developed by a Microsoft employee in 1991, specifically to meet the need for commands useful in a network logon script while retaining the simple ‘feel’ of a .cmd file.
  • Windows Script Hostย (.vbsย ,ย .jsย andย .wsf)ย โ€” released by Microsoft in 1998, and consisting of cscript.exe and wscript.exe, runs scripts written inย VBScriptย orย JScript. It can run them in windowed mode (with the wscript.exe host) or in console-based mode (with the cscript.exe host). They have been a part of Windows sinceย Windows 98.
  • PowerShellย (.ps1)ย โ€” released in 2006 by Microsoft and can operate withย Windows XPย (SP2/SP3) and later versions. PowerShell can operate both interactively (from a command-line interface) and also via saved scripts, and has a strong resemblance toย Unixย shells.
  • Unix-style shell scripting languages can be used if a Unix compatibility tool, such asย Cygwin, is installed.
  • Cross-platformย scripting tools includingย Perl,ย Python,ย Ruby,ย Rexx,ย Node.jsย andย PHPย are available for Windows.

Script files run if the filename without extension is entered. There are rules of precedence governing interpretation of, say,ย DoThisย ifย DoThis.cmd,ย DoThis.bat,ย DoThis.exe, etc. exist; by defaultย DoThis.cmdย has highest priority. This default order may be modified in newer operating systems by the user-settableย PATHEXTย environment variable.


For privacy reasons YouTube needs your permission to be loaded. For more details, please see our Privacy Policy – Legal Disclaimer – Site Content Policy.

Related Videos:

Bernard Aybouts - Blog - Miltonmarketing.com

Related Posts:

Introduction to Batch File Viruses

Directory Listing Batch Script

Directory Listing Batch Script

Scripted Harmony: Automating File Sorting into Named Folders

Maximizing Memory: The Humorous History of DOS and the 640K Limit – A Tech Enthusiast’s Guide

The Longevity Blueprint: AI-Powered Health Optimization

Current step:1AI-Human Medical Analyzer: Smarter, Personalized Health
2AI-Human Medical Analyzer: Smarter, Personalized Health

> SYS.HEALTH: AI-Human Medical Analyzer_

// Revolutionize Your Diagnostics

Experience the perfect blend of cutting-edge AI precision and expert human care. Our revolutionary analyzer turns your raw health data into personalized, actionable insights tailored just for you.

> INITIALIZING_BIOMETRIC_SCAN...

[+] DATA_INPUT

Securely upload complex health parameters, including lab bloodwork and comprehensive medical history.

[+] PROCESSING

Advanced algorithmic parsing combined with human-level oversight ensures hyper-accurate data interpretation.

[+] OUTPUT_MATRIX

Receive smarter, faster, and truly personalized care strategies to take immediate charge of your health journey.

A name/nickname is required to continue.

> TRANSLATION_MATRIX_ACTIVE...
[ LANG_EN ]
Knowledge Heals, Prevention Protects
[ LANG_HI ]
เคœเฅเคžเคพเคจ เค เฅ€เค• เค•เคฐเคคเคพ เคนเฅˆ, เคฐเฅ‹เค•เคฅเคพเคฎ เคธเฅเคฐเค•เฅเคทเคพ เค•เคฐเคคเฅ€ เคนเฅˆ
[ LANG_ZH ]
็Ÿฅ่ฏ†ๆฒปๆ„ˆ๏ผŒ้ข„้˜ฒไฟๆŠค
[ LANG_JA ]
็Ÿฅ่ญ˜ใฏ็™’ใ—ใ€ไบˆ้˜ฒใฏๅฎˆใ‚‹
[ LANG_HE ]
ื”ื™ื“ืข ืžืจืคื, ื”ืžื ื™ืขื” ืžื’ื ื”
[ LANG_AR ]
ุงู„ู…ุนุฑูุฉ ุชูุดููŠุŒ ูˆุงู„ูˆู‚ุงูŠุฉ ุชุญู…ูŠ
[ LANG_FR ]
La connaissance guรฉrit, la prรฉvention protรจge

> SYS.AUTH: Data Processing Consent_

[ AWAITING_AUTHORIZATION ] By providing consent, you allow us to process your uploaded data through our proprietary AI-Human analysis system.

  • [+] SECURE_REVIEW: This ensures your information is carefully reviewed using advanced AI technology and certified professional oversight to deliver personalized health insights.
  • [+] PRIVACY_LOCK: Your privacy is our strict priority. Your data will only be used for this specific diagnostic purpose.

> SYS.UPLOAD: Share Medical Records [OPTIONAL]_

[ USER_CONTROL_ACTIVE ] Uploading your medical records during registration is entirely optional. You can choose to bypass this step and provide data later if it suits your timeline.

You dictate the data flow: share as much or as little as youโ€™re comfortable with, and let us guide you toward better health.

[+] FORMAT_SUPPORT

We accept all file formats, including photos, PDFs, text documents, and raw official medical data.

[+] DATA_YIELD

Increased inputs correlate with higher precision. The more info you share, the better we tailor your personalized insights.

> NEXT_STEPS: Post-Registration Protocol_

Once your registration is complete, a human specialist from our team will personally reach out to you within 3-10 business days. We will discuss your health journey and map out exactly how we can support you.

About the Author: Bernard Aybout (Virii8)

Avatar Of Bernard Aybout (Virii8)
I am a dedicated technology enthusiast with over 45 years of life experience, passionate about computers, AI, emerging technologies, and their real-world impact. As the founder of my personal blog, MiltonMarketing.com, I explore how AI, health tech, engineering, finance, and other advanced fields leverage innovationโ€”not as a replacement for human expertise, but as a tool to enhance it. My focus is on bridging the gap between cutting-edge technology and practical applications, ensuring ethical, responsible, and transformative use across industries. MiltonMarketing.com is more than just a tech blogโ€”it's a growing platform for expert insights. We welcome qualified writers and industry professionals from IT, AI, healthcare, engineering, HVAC, automotive, finance, and beyond to contribute their knowledge. If you have expertise to share in how AI and technology shape industries while complementing human skills, join us in driving meaningful conversations about the future of innovation. ๐Ÿš€