Professional Documents
Culture Documents
Windows commands
assign
The command redirects requests for disk operations on one drive to a different drive.
assign [x[:]=y[:][...]]
assign /STATUS
Options:
If typed without parameters then all drive letters are reset to original assignments.
The command is available in MS-DOS 5.00.
append
(External)
Display or sets the search path for data files. DOS will search the specified path(s) if the file is
not found in the current path. This had some creative uses, such as allowing non-CD based
games to be run from the CD, with configuration/save files stored on the HD.
append;
append [d:]path[;][d:]path[...]
append [/X:on|off][/E]
attrib
Change or view the attributes of one or more files. It defaults to displaying the attributes
of all files in the current directory.
Options:
o S - System
o H - Hidden
[drive:][path][filename]
Specifies a file or files for attrib to process.
o /D - Process folders as well.
call
Calls one batch program from another. A new batch file context is created with the
specified arguments and control is passed to the statement after the label specified.
Syntax:
cd or chdir
Change current directory. Displays the current working directory when used without a
path parameter.
cd
cd f:
cd directory
chdir e:directory
changes the working directory on E: to directory.
cd ..
changes the working directory to the parent directory (up one directory level).
cd \
changes the working directory to the root (top level) directory of the current drive.
chcp
Changes the code page used to display character glyphs in a console window.
chcp [codepage]
With a numeric parameter, this command changes the codepage setting to codepage. Without a
parameter, the command displays the currently active codepage.
chkdsk
Options:
/F : Fixes errors on the disk (without /F , chkdsk only detects errors)
/P : Forces a full disk verification
/R : Searches for defective sectors and recovers legible information (applies /F)
choice
Allows for batch files to prompt the user to select one item from a set of single-character
choices.
Introduced in MS-DOS 6;[1] DR-DOS 7.03.[2]
cls
Copies files from one location to another. The destination defaults to the current
directory. If multiple source files are indicated, the destination must be a directory, or an
error will result.
Syntax:
copy filespec [destination]
Files may be copied to devices. For example, copy file lpt1 sends the file to the
printer on LPT1. copy file con outputs file to the screen ("console"), which can also be
done using type file. Devices themselves may be copied: copy con file takes the
text typed into the console and puts it into file, stopping when EOF (Ctrl+Z) is typed.
Files may be concatenated using +. For example, copy file1+file2 file_cat will
concatenate the files and output them as file_cat. There are two switches to modify the
command's behaviour, /a (text mode, the default) and /b (binary mode). In text mode,
copy will stop when it reaches the EOF character; in binary mode, the files will be
concatenated in their entirety, ignoring EOF characters.
Examples of usage:
copy /a alpha.txt + beta.txt gamma.txt
copy /b alpha.mpg + beta.mpg gamma.mpg
Equivalent Unix commands are cp (for copying) and cat (for concatenation). Device
files may be copied in Unix as well, e.g. cp file /dev/tty will display a file on the
screen (but cat file is more commonly used here).
Equivalent RT-11/RSX-11/OpenVMS command is copy.
ctty
Example of usage:
ctty COM1
defrag
del or erase
Options
deltree
Deletes a directory along with all of the files and subdirectories that it contains.
Normally, it will ask for confirmation of such a drastic action.
deltree [/y] directory
The /y parameter, if present, tells the deltree command to carry out without first prompting for
confirmation.
The deltree command is not included in recent Microsoft Windows operating systems.
Deleting a non-empty directory in those versions of Windows where the command is not
included, can be achieved by using the rmdir command as in the following example:
In Unix, the functionality of deltree is provided by the rm command with the parameter -r (or
-rf for the /y switch).
dir
The dir command typed by itself, displays the disk's volume label and serial number; one
directory or filename per line, including the filename extension, the file size in bytes, and the
date and time the file was last modified; and the total number of files listed, their cumulative
size, and the free space (in bytes) remaining on the disk. The command is one of the few
commands that exist from the first versions of DOS.
dir [drive:][path][filename] [parameters]
/W : Displays the listing in wide format, with as many as five filenames or directory
names on each line.
/P : Pause at every page
Possible attributes for the A parameter are D (directories), R (read-only files), H (hidden files), A
(files/directories with the archive bit on), and S (system files). The prefix - negates an attribute;
attributes can be combined (e.g. /A:DA means directories with the archive bit on).
Possible sort orders are N (name), S (size), E (extension), D (date and time), A (last access date),
and G (group directories first). The prefix - reverses the order.
The default parameters of dir can be set using the DIRCMD environment variable.
Equivalent to the Unix command ls (the option -l is "long" list format, it works the opposite
way from /w.)
echo
Prints its own arguments back out to the DOS equivalent of the standard output stream.
Usually, this means directly to the screen, but the output of echo can be redirected like
any other command. Often used in batch files to print text out to the user.
echo this is text Outputs 'this is text'
echo. Outputs a blank line
Another important use of the echo command is to toggle echoing of commands on and
off in batch files.
echo on turns on echoing of commands
echo off turns off echoing of commands
Traditionally batch files begin with the @echo off statement. This says to the interpreter
that echoing of commands should be off during the whole execution of the batch file thus
resulting in a "tidier" output. The @ symbol declares that this particular command (echo
off) should also be executed without echo. For example the following 2 batch files are
equivalent:
Batch1.bat:
@echo off
echo The files in your root directory:
dir /b /a-d c:\
Batch2.bat:
@echo The files in your root directory:
@dir /b /a-d c:\
Echo can be used to write to files directly from the console, by redirecting the output
stream:
echo text > filename
Echo can also be used to append to files directly from the console, again by redirecting
the output stream:
echo text >> filename
To type more than one line from the console into a file, use copy con (above).
Equivalent to the Unix command echo.
exe2bin
Converts an executable (.exe) file into a binary file with the extension .com, which is a
memory image of the program.
The size of the resident code and data sections combined in the input .exe file must be
less than 64KB. The file must also have no stack segment.
exit
Exits the current command processor. If the exit is used at the primary command, it has
no effect unless in a DOS window under Microsoft Windows, in which case the window
is closed and the user returns to the desktop.
exit [/B]
/B When used within a batch script, exits the script without closing the
calling DOS window
Exit also exists in Unix-shells. If an exit command is used in the primary command shell
under Unix, however, it will logoff the user, similar to the control-D keystroke.
fastopen
fc or comp
Compares two files or sets of files and displays the differences between them.
FC [/A] [/C] [/L] [/LBn] [/N] [/T] [/W] [/nnnn] [drive1:][path1]filename1
[drive2:][path2]filename2
FC /B [drive1:][path1]filename1 [drive2:][path2]filename2
/A Displays only first and last lines for each set of differences.
/B Performs a binary comparison.
/C Disregards the case of letters.
/L Compares files as ASCII text.
/LBn Sets the maximum consecutive mismatches to the specified number of
lines.
/N Displays the line numbers on an ASCII comparison.
/T Does not expand tabs to spaces.
/W Compresses white space (tabs and spaces) for comparison.
/nnnn Specifies the number of consecutive lines that must match after a
mismatch.
[drive1:][path1]filename1 Specifies the first file or set of files to
compare.
[drive2:][path2]filename2 Specifies the second file or set of files to
compare.[citation needed]
Equivalent to the Unix commands comm, cmp and diff.
fdisk
Manipulates hard disk partition tables. The name derives from IBM's habit of calling hard
drives fixed disks. When run from the command line, it displays a menu of various
partitioning operations:
1. Create DOS partition or Logical DOS Drive
2. Set active partition
3. Delete partition or Logical DOS Drive
4. Display partition information
5. Change current fixed disk drive (only available if the computer has more
than one hard drive)
FDISK /MBR installs a standard master boot record on the hard drive.
FDISK /MBR #: where # is other partition on system. Completes above command on
indicated partition.
eg: "C:\FDISK /MBR D:" would install boot record on D:\
partition.
Fdisk exists under Unix with the same name, but it is an entirely different program.
However they share purposes.
find
A filter to find lines in the input data stream that contain or don't contain a specified
string and send these to the output data stream.
Find may also be used as a pipe.
find "keyword" < ''inputfilename'' > ''outputfilename''
If a pathname is not specified, FIND searches the text typed at the prompt
or piped from another command.
Equivalent to the Unix command grep. The Unix command find performs an entirely
different function.
format
Delete all the files on the disk and reformat it for MS-DOS
In most cases, this should only be used on floppy drives or other removable media. This
command can potentially erase everything on a computer's hard disk.
/autotest and /backup are undocumented features. Both will format the drive without a
confirmation prompt.
format [options] drive
FORMAT drive: [/V[:label]] [/Q] [/F:size] [/B | /S] [/C]
FORMAT drive: [/V[:label]] [/Q] [/T:tracks /N:sectors] [/B | /S] [/C]
FORMAT drive: [/V[:label]] [/Q] [/1] [/4] [/B | /S] [/C]
FORMAT drive: [/Q] [/1] [/4] [/8] [/B | /S] [/C]
/V[:label] Specifies the volume label.
/Q Performs a quick format.
/F:size Specifies the size of the floppy disk to format (such
as 160, 180, 320, 360, 720, 1.2, 1.44, 2.88).
/B Allocates space on the formatted disk for system files.
/S Copies system files to the formatted disk.
/T:tracks Specifies the number of tracks per disk side.
/N:sectors Specifies the number of sectors per track.
/1 Formats a single side of a floppy disk.
/4 Formats a 5.25-inch 360K floppy disk in a high-density drive.
/8 Formats eight sectors per track.
/C Tests clusters that are currently marked "bad."
Known as a joke among UNIX users of that time since every user on the machine could easily
cause damage with just one command. Therefore, it was known in the UNIX community as "The
big DOS timesaver".
There is also an undocumented /u parameter for "unconditional" that will write strings of
zeros on every sector.
Equivalent to the Unix command mkfs.
Equivalent in RT-11/RSX-11/OpenVMS operating systems line is format command
which can not create filesystem. After formatting one should use initialize (contracted
to init) command to create filesystem (Equivalent to MS-DOS command format /q or
"quick format").
help
Network PCs using a null modem cable or LapLink cable. The server-side version of
InterLnk, it also immobilizes the machine it's running on as it is an active app (As
opposed to a TSR) which must be running for any transfer to take place. DR-DOS'
filelink is executed on both the client and server.
New in MS-DOS 6.[3]
No direct Unix equivalent, though some Unices offer the ability to network computers
with TCP/IP through null modem or Laplink cables using PLIP or SLIP.
join
label
Changes the label on a logical drive, such as a hard disk partition or a floppy disk.
In Unix and Unix-like systems, this differs from filesystem to filesystem. e2label can be
used for ext2 partitions.
lh
loadfix
Loads a program above the first 64K of memory, and runs the program.
loadfix [drive:][path]filename
Included only in MS/PC-DOS. DR-DOS used memmax, which opened or closed lower,
upper, and video memory access, to block the lower 64K of memory.[4]
loadhigh
md or mkdir
Makes a new directory. The parent of the directory specified will be created if it does not
already exist.
md directory
Equivalent to the Unix command mkdir.
mem
Options:
Starting from version 6, MS-DOS included the external program MemMaker which was
used to free system memory (especially Conventional memory) by automatically
reconfiguring the AUTOEXEC.BAT and CONFIG.SYS files. This was usually done by
moving TSR Programs to the Upper memory. The whole process required three system
restarts. Before the first restart the user was asked whether he wanted to enable EMS
Memory or not.
The use of MemMaker was popular among gamers who wanted to enable or disable
Expanded memory in order to run a game which required EMS or not. Better results
could be achieved by an experienced user manually configuring the startup files to
achieve greater free memory yield.
Options:
/BATCH Runs MemMaker in batch (unattended) mode. In batch mode, MemMaker takes
the default action at all prompts.
/UNDO Instructs MemMaker to undo its most recent changes.
mode
Configures system devices. Changes graphics modes, adjusts keyboard settings, prepares
code pages, and sets up port redirection.[5]
more
Pages through the output so that you can view more than one screen of text.
command | more
Equivalent to the Unix commands more and less.
More may also be used as a filter.
more < inputfilename
move
msd
Main article: Microsoft Diagnostics
Provides detailed technical information about the computer's hardware and software.
msd
New in MS-DOS 6;[6] the PC-DOS version of this command is QCONFIG.[citation needed]
No Unix equivalent, however in GNU/Linux similar type of information may be obtained
from various text files in /proc directory.
pause
Suspends processing of a batch program and displays the message 'Press any key to
continue. . .'.
pcpark
Parks the hard disk heads in order to enable safe shutdown; only used on early versions.
pcpark
No Unix equivalent.
MS-DOS 3.2 (and possibly others) used the command HHSET
Options:
/D device : Specifies the name of the print devices. Default value is LPT1
/P filename : Add files in the print queue
/T : Removes all files from the print queue
/C filename : Removes a file from the print queue
This command was introduced in MS-DOS version 2. Before that there was no built-in support
for background printing files. The user would usually use the copy command to copy files to
LPT1.
rd or rmdir
Remove a directory, which by default must be empty of files for the command to succeed
(the /s flag removes this restriction).
rd directory
Equivalent to the Unix command rmdir.
rem
Remark statement, normally used within a batch file. An alternative way not to run a
specific statement in a batch file is creating a label that will never be used, ::.
rem > newfilename
In Unix, the # sign can be used to start a comment.
ren
Renames a file. Unlike the move command, this command cannot be used to rename
subdirectories, or rename files across drives.
ren filename newname
You can rename files in another directory by using the PATH parameter:
ren [path]|[filename] [newfilename]
An example could be:
ren c:\Windows filex.txt filey.txt
On DOS with long filename support, care must be taken when directories have spaces in
their names like "Documents and Settings". In these cases double-quotes are used to
enclose them:
ren c:\"Documents and Settings"\"All Users"\Desktop filex.txt filey.txt
Mass renames can be accomplished by the use of wildcards. For example, the following
command will change the extension of all files in the current directory which currently
have the extension htm to html:
ren *.htm *.html
In Unix, this functionality of a simple move is provided by the mv command, while batch
renames can be done using the rename command.
scandisk
Disk diagnostic utility. Scandisk was a replacement for the chkdsk utility, starting with
later versions of MS-DOS. Its primary advantages over chkdsk is that it is more reliable
and has the ability to run a surface scan which finds and marks bad clusters on the disk.
chkdsk had surface scan and bad cluster detection functionality included, and was used
again on Windows NT based operating systems.
Equivalent to the Unix command fsck.
set
share
sort
A filter to sort lines in the input data stream and send them to the output data stream.
sort < inputfilename > outputfilename
Equivalent to the Unix command sort.
subst
sys
tree
truename
truename
or
truename drivename
or
truename filename
or
truename directory
If typed without a parameter then the current active drive pathname is displayed.
MS-DOS can find files and directories given their names, without full path information,
if the search object is on a path specified by the environment variable PATH. For example,
if PATH includes C:\PROGRAMS, and file MYPROG.EXE is on this directory, then if MYPROG is
typed at the command prompt, the command processor will execute
C:\PROGRAMS\MYPROG.EXE
the TRUENAME command will expand a name in an abbreviated form which the command
processor can recognise into its full form, and display the result. It can see through SUBST
and JOIN to find the actual directory. In the above example,
TRUENAME MYPROG
would display
C:\PROGRAMS\MYPROG.EXE
and for a substituted drive set up by
subst d: c:\util\test
the command
truename d:\test.exe
will display
c:\util\test\test.exe
This command also displays the UNC pathnames of mapped network or local CD drives.
This command is an undocumented DOS command. The help switch "/?" defines it as a
"Reserved command name". It is available in MS-DOS 5.00.
This command is similar to the Unix which command, which, given an executable found
in $PATH, would give a full path and name. The C library function realpath performs
this function.
type
Display a file. The more command is frequently used in conjunction with this command,
e.g. type long-text-file | more.
type filename
Equivalent to the Unix command cat.
undelete
Restores file previously deleted with del. By default all recoverable files in the working
directory are restored. The options are used to change this behavior. If the MS-DOS
mirror TSR program is used, then deletion tracking files are created and can be used by
undelete.
Syntax:
undelete [filespec] [/list|/all][/dos|/dt]
Options:
In Unix and Unix-like systems this differs from filesystem to filesystem. People who use
the ext2 filesystem can try the command e2undel.
ver
verify
Enables or disables the feature to determine if files have been correctly written to disk.
If no parameter is provided, the command will display the current setting.[7]
verify [on|off]
xcopy
References
1. ^ http://www.computerhope.com/choicehl.htm
2. ^ http://www.drdos.com/dosdoc/usergeng/07ugch7.htm
3. ^ a b c EasyDOS Command Index
4. ^ DR DOS 6.0 User Guide. Digital Research. 1991.
5. ^ http://www.computerhope.com/modehlp.htm
6. ^ http://www.computerhope.com/msdhlp.htm
7. ^ http://www.csulb.edu/~murdock/verify.html
External links
Command Reference : Microsoft TechNet Database "Command Reference"
The MS-DOS 6 Technical Reference on TechNet contains the official Microsoft MS-
DOS 6 command reference documention.
DR-DOS 7.03 online manual
There are several guides to DOS commands available that are licenced under the GNU Free
Documentation License:
The FreeDOS Spec at SourceForge is a plaintext specification, written in 1999, for how
DOS commands should work in FreeDOS
MS-DOS commands
A Collection of Undocumented and Obscure Features in Various MS-DOS Versions