最全的批处理命令.docx
《最全的批处理命令.docx》由会员分享,可在线阅读,更多相关《最全的批处理命令.docx(78页珍藏版)》请在冰豆网上搜索。
最全的批处理命令
第一章批处理基础
第一节常用批处理内部命令简介
批处理定义:
顾名思义,批处理文件是将一系列命令按一定的顺序集合为一个可执行的文本文件,其扩展名为BAT或者CMD。
这些命令统称批处理命令。
小知识:
可以在键盘上按下Ctrl+C组合键来强行终止一个批处理的执行过程。
了解了大概意思后,我们正式开始学习.先看一个简单的例子!
@echooff
echo"欢迎来到非常BAT!
"
pause
把上面的3条命令保存为文件test.bat或者test.cmd然后执行,
他就会在屏幕上显示以下二行话:
欢迎来到非常BAT!
请按任意键继续...
这就是一个简单批处理文件了,这个批处理文件一共就用了2条命令"echo"和"pause"还有一个特殊符号"@"
从上面这个简单的批处理中,我们可以发现其实批处理就是运用一些含有特殊意义的符号和一些完成指定功能的命令组合而成,那么在批处理中有多少这样的特殊符号和功能命令呢?
我们现在就来仔细了解一下一些最常用的!
(以下内容来源网络,请各位仔细阅读,好进入下节的实例说明)
======================================================
批处理的常见命令(未列举的命令还比较多,请查阅帮助信息)
1、REM和:
:
2、ECHO和@
3、PAUSE
4、ERRORLEVEL
5、TITLE
6、COLOR
7、mode配置系统设备
8、GOTO和:
9、FIND
10、START
11、assoc和ftype
12、pushd和popd
13、CALL
14、shift
15、IF
16、setlocal与变量延迟
17、ATTRIB 显示或更改文件属性
介绍命令
1、REM和:
:
REM为注释命令,一般用来给程序加上注解,该命令后的内容不被执行,但能回显。
其次,:
:
也可以起到rem的注释作用,而且更简洁有效;但有两点需要注意:
第一,任何以冒号:
开头的字符行,在批处理中都被视作标号,而直接忽略其后的所有内容。
有效标号:
冒号后紧跟一个以字母数字开头的字符串,goto语句可以识别。
无效标号:
冒号后紧跟一个非字母数字的一个特殊符号,goto无法识别的标号,可以起到注释作用,所以:
:
常被用作注释符号,其实:
+也可起注释作用。
第二,与rem不同的是,:
:
后的字符行在执行时不会回显,无论是否用echoon打开命令行回显状态,因为命令解释器不认为他是一个有效的命令行,就此点来看,rem在某些场合下将比:
:
更为适用;另外,rem可以用于config.sys文件中。
行内注释格式:
%注释内容% (不常用,慎用)
2、ECHO和@
@字符放在命令前将关闭该命令回显,无论此时echo是否为打开状态。
echo命令的作用列举如下:
(1)打开回显或关闭回显功能
格式:
echo[{on|off}]
如果想关闭“ECHOOFF”命令行自身的显示,则需要在该命令行前加上“@”。
(2)显示当前ECHO设置状态
格式:
echo
(3)输出提示信息
格式:
ECHO信息内容
上述是ECHO命令常见的三种用法,也是大家熟悉和会用的,但作为DOS命令淘金者你还应该知道下面的技巧:
(4)关闭DOS命令提示符
在DOS提示符状态下键入ECHOOFF,能够关闭DOS提示符的显示使屏幕只留下光标,直至键入ECHOON,提示符才会重新出现。
(5)输出空行,即相当于输入一个回车
格式:
ECHO.
值得注意的是命令行中的“.”要紧跟在ECHO后面中间不能有空格,否则“.”将被当作提示信息输出到屏幕。
另外“.”可以用,:
;”/[\]+等任一符号替代。
命令ECHO.输出的回车,经DOS管道转向可以作为其它命令的输入,比如echo.|time即相当于在TIME命令执行后给出一个回车。
所以执行时系统会在显示当前时间后,自动返回到DOS提示符状态
(6)答复命令中的提问
格式:
ECHO答复语|命令文件名
上述格式可以用于简化一些需要人机对话的命令(如:
CHKDSK/F;FORMATDrive:
;del*.*)的操作,它是通过DOS管道命令把ECHO命令输出的预置答复语作为人机对话命令的输入。
下面的例子就相当于在调用的命令出现人机对话时输入“Y”回车:
C:
>ECHOY|CHKDSK/F
C:
>ECHOY|DELA:
*.*
(7)建立新文件或增加文件内容
格式:
ECHO文件内容>文件名
ECHO文件内容>>文件名
例如:
C:
>ECHO@ECHOOFF>AUTOEXEC.BAT建立自动批处理文件
C:
>ECHOC:
\CPAV\BOOTSAFE>>AUTOEXEC.BAT向自动批处理文件中追加内容
C:
>TYPEAUTOEXEC.BAT显示该自动批处理文件
@ECHOOFF
C:
\CPAV\BOOTSAFE
(8)向打印机输出打印内容或打印控制码
格式:
ECHO打印机控制码>;PRN
ECHO打印内容>;PRN
下面的例子是向M-1724打印机输入打印控制码。
<Alt>156是按住Alt键在小键盘键入156,类似情况依此类推:
C:
>ECHO+156+42+116>;PRN(输入下划线命令FS*t)
C:
>ECHO[email=+155@]+155@>;PRN[/email](输入初始化命令ESC@)
C:
>ECHO.>;PRN(换行)
(9)使喇叭鸣响
C:
>ECHO^G
“^G”是在dos窗口中用Ctrl+G或Alt+007输入,输入多个^G可以产生多声鸣响。
使用方法是直接将其加入批处理文件中或做成批处理文件调用。
这里的“^G”属于特殊符号的使用,请看本文后面的章节
3、PAUSE
PAUSE,玩游戏的人都知道,暂停的意思
在这里就是停止系统命令的执行并显示下面的内容。
例:
PAUSE
运行显示:
请按任意键继续...
要显示其他提示语,可以这样用:
Echo其他提示语&pause>nul
4、errorlevel
程序返回码
echo%errorlevel%
每个命令运行结束,可以用这个命令行格式查看返回码
用于判断刚才的命令是否执行成功
默认值为0,一般命令执行出错会设errorlevel为1
5、title
设置cmd窗口的标题
title新标题 #可以看到cmd窗口的标题栏变了
6、COLOR
设置默认的控制台前景和背景颜色。
COLOR[attr]
attr 指定控制台输出的颜色属性
颜色属性由两个十六进制数字指定--第一个为背景,第二个则为
前景。
每个数字可以为以下任何值之一:
0=黑色 8=灰色
1=蓝色 9=淡蓝色
2=绿色 A=淡绿色
3=湖蓝色 B=淡浅绿色
4=红色 C=淡红色
5=紫色 D=淡紫色
6=黄色 E=淡黄色
7=白色 F=亮白色
如果没有给定任何参数,该命令会将颜色还原到CMD.EXE启动时
的颜色。
这个值来自当前控制台窗口、/T开关或
DefaultColor注册表值。
如果用相同的前景和背景颜色来执行COLOR命令,COLOR命令
会将ERRORLEVEL设置为1。
例如:
"COLORfc"在亮白色上产生亮红色
7、mode配置系统设备
配置系统设备。
串行口:
MODECOMm[:
][BAUD=b][PARITY=p][DATA=d][STOP=s]
[to=on|off][xon=on|off][odsr=on|off]
[octs=on|off][dtr=on|off|hs]
[rts=on|off|hs|tg][idsr=on|off]
设备状态:
MODE[device][/STATUS]
打印重定向:
MODELPTn[:
]=COMm[:
]
选定代码页:
MODECON[:
]CPSELECT=yyy
代码页状态:
MODECON[:
]CP[/STATUS]
显示模式:
MODECON[:
][COLS=c][LINES=n]
击键率:
MODECON[:
][RATE=rDELAY=d]
例:
modeconcols=113lines=15&color9f
此命令设置DOS窗口大小:
15行,113列
8、GOTO和:
GOTO会点编程的朋友就会知道这是跳转的意思。
在批处理中允许以“:
XXX”来构建一个标号,然后用GOTOXXX跳转到标号:
XXX处,然后执行标号后的命令。
例:
if{%1}=={}gotonoparms
if"%2"==""gotonoparms
标签的名字可以随便起,但是最好是有意义的字符串啦,前加个冒号用来表示这个字符串是标签,goto命令就是根据这个冒号(:
)来寻找下一步跳到到那里。
最好有一些说明这样你别人看起来才会理解你的意图啊。
例:
@echooff
:
start
set/avar+=1
echo%var%
if%var%leq3GOTOstart
pause
运行显示:
1
2
3
4
10、start命令
批处理中调用外部程序的命令(该外部程序在新窗口中运行,批处理程序继续往下执行,不理会外部程序的运行状况),如果直接运行外部程序则必须等外部程序完成后才继续执行剩下的指令
例:
startexplorerd:
\
调用图形界面打开D盘
11、assoc和ftype
文件关联
assoc设置'文件扩展名'关联,关联到'文件类型'
ftype设置'文件类型'关联,关联到'执行程序和参数'
当你双击一个.txt文件时,windows并不是根据.txt直接判断用notepad.exe打开
而是先判断.txt属于txtfile'文件类型'
再调用txtfile关联的命令行txtfile=%SystemRoot%\system32\NOTEPAD.EXE%1
可以在"文件夹选项"→"文件类型"里修改这2种关联
assoc #显示所有'文件扩展名'关联
assoc.txt #显示.txt代表的'文件类型',结果显示.txt=txtfile
assoc.doc #显示.doc代表的'文件类型',结果显示.doc=Word.Document.8
assoc.exe #显示.exe代表的'文件类型',结果显示.exe=exefile
ftype #显示所有'文件类型'关联
ftypeexefile #显示exefile类型关联的命令行,结果显示exefile="%1"%*
assoc.txt=Word.Document.8
设置.txt为word类型的文档,可以看到.txt文件的图标都变了
assoc.txt=txtfile
恢复.txt的正确关联
ftypeexefile="%1"%*
恢复exefile的正确关联
如果该关联已经被破坏,可以运行,再输入这条命令
12、pushd和popd
切换当前目录
@echooff
c:
&cd\&mdmp3 #在C:
\建立mp3文件夹
mdd:
\mp4 #在D:
\建立mp4文件夹
cd/dd:
\mp4 #更改当前目录为d:
\mp4
pushdc:
\mp3 #保存当前目录,并切换当前目录为c:
\mp3
popd #恢复当前目录为刚才保存的d:
\mp4
一般用处不大,在当前目录名不确定时,会有点帮助。
(dos编程中很有用)
13、CALL
CALL命令可以在批处理执行过程中调用另一个批处理,当另一个批处理执行完后,再继续执行原来的批处理
CALLcommand
调用一条批处理命令,和直接执行命令效果一样,特殊情况下很有用,比如变量的多级嵌套,见教程后面。
在批处理编程中,可以根据一定条件生成命令字符串,用call可以执行该字符串,见例子。
CALL[drive:
][path]filename[batch-parameters]
调用的其它批处理程序。
filename参数必须具有.bat或.cmd扩展名。
CALL:
labelarguments
调用本文件内命令段,相当于子程序。
被调用的命令段以标签:
label开头
以命令goto:
eof结尾。
另外,批脚本文本参数参照(%0、%1、等等)已如下改变:
批脚本里的%*指出所有的参数(如%1%2%3%4%5...)
批参数(%n)的替代已被增强。
您可以使用以下语法:
(看不明白的直接运行后面的例子)
%~1 -删除引号("),扩充%1
%~f1 -将%1扩充到一个完全合格的路径名
%~d1 -仅将%1扩充到一个驱动器号
%~p1 -仅将%1扩充到一个路径
%~n1 -仅将%1扩充到一个文件名
%~x1 -仅将%1扩充到一个文件扩展名
%~s1 -扩充的路径指含有短名
%~a1 -将%1扩充到文件属性
%~t1 -将%1扩充到文件的日期/时间
%~z1 -将%1扩充到文件的大小
%~$PATH:
1-查找列在PATH环境变量的目录,并将%1
扩充到找到的第一个完全合格的名称。
如果环境
变量名未被定义,或者没有找到文件,此组合键会
扩充到空字符串
可以组合修定符来取得多重结果:
%~dp1 -只将%1扩展到驱动器号和路径
%~nx1 -只将%1扩展到文件名和扩展名
%~dp$PATH:
1-在列在PATH环境变量中的目录里查找%1,
并扩展到找到的第一个文件的驱动器号和路径。
%~ftza1 -将%1扩展到类似DIR的输出行。
在上面的例子中,%1和PATH可以被其他有效数值替换。
%~语法被一个有效参数号码终止。
%~修定符不能跟%*使用
注意:
参数扩充时不理会参数所代表的文件是否真实存在,均以当前目录进行扩展
要理解上面的知识,下面的例子很关键。
例:
@echooff
Echo产生一个临时文件>tmp.txt
Rem下行先保存当前目录,再将c:
\windows设为当前目录
pushdc:
\windows
Call:
subtmp.txt
Rem下行恢复前次的当前目录
Popd
Call:
subtmp.txt
pause
Deltmp.txt
exit
:
sub
Echo删除引号:
%~1
Echo扩充到路径:
%~f1
Echo扩充到一个驱动器号:
%~d1
Echo扩充到一个路径:
%~p1
Echo扩充到一个文件名:
%~n1
Echo扩充到一个文件扩展名:
%~x1
Echo扩充的路径指含有短名:
%~s1
Echo扩充到文件属性:
%~a1
Echo扩充到文件的日期/时间:
%~t1
Echo扩充到文件的大小:
%~z1
Echo扩展到驱动器号和路径:
%~dp1
Echo扩展到文件名和扩展名:
%~nx1
Echo扩展到类似DIR的输出行:
%~ftza1
Echo.
Goto:
eof
例:
setaa=123456
setcmdstr=echo%aa%
call%cmdstr%
pause
本例中如果不用call,而直接运行%cmdstr%,将显示结果%aa%,而不是123456
14、shift
更改批处理文件中可替换参数的位置。
SHIFT[/n]
如果命令扩展名被启用,SHIFT命令支持/n命令行开关;该命令行开关告诉
命令从第n个参数开始移位;n介于零和八之间。
例如:
SHIFT/2
会将%3移位到%2,将%4移位到%3,等等;并且不影响%0和%1。
15、IF
IF条件判断语句,语法格式如下:
IF[NOT]ERRORLEVELnumbercommand
IF[NOT]string1==string2command
IF[NOT]EXISTfilenamecommand
下面逐一介绍,更详细的分析请看后面章节。
(1)IF[NOT]ERRORLEVELnumbercommand
IFERRORLEVEL这个句子必须放在某一个命令的后面,执行命令后由IFERRORLEVEL来判断命令的返回值。
Number的数字取值范围0~255,判断时值的排列顺序应该由大到小。
返回的值大于等于指定的值时,条件成立
例:
@echooff
dirc:
rem退出代码为>=1就跳至标题1处执行,>=0就跳至标题0处执行
IFERRORLEVEL1goto1
IFERRORLEVEL0goto0
Rem上面的两行不可交换位置,否则失败了也显示成功。
:
0
echo命令执行成功!
Rem程序执行完毕跳至标题exit处退出
gotoexit
:
1
echo命令执行失败!
Rem程序执行完毕跳至标题exit处退出
gotoexit
:
exit
pause
运行显示:
命令执行成功!
(2)IF[NOT]string1==string2command
string1和string2都为字符的数据,英文内字符的大小写将看作不同,这个条件中的等于号必须是两个(绝对相等的意思)
条件相等后即执行后面的command
检测当前变量的值做出判断,为了防止字符串中含有空格,可用以下格式
if[NOT]{string1}=={string2}command
if[NOT][string1]==[string2]command
if[NOT]"string1"=="string2"command
这种写法实际上将括号或引号当成字符串的一部分了,只要等号左右两边一致就行了,比如下面的写法就不行:
if{string1}==[string2]command
(3)IF[NOT]EXISTfilenamecommand
EXISTfilename为文件或目录存在的意思
echooff
IFEXISTautoexec.batecho文件存在!
IFnotEXISTautoexec.batecho文件不存在!
这个批处理大家可以放在C盘和D盘分别执行,看看效果
16、setlocal与变量延迟
本条内容引用[英雄出品]的批处理教程:
要想进阶,变量延迟是必过的一关!
所以这一部分希望你能认真看。
为了更好的说明问题,我们先引入一个例子。
例1:
@echooff
seta=4
seta=5&echo%a%
pause
结果:
4
解说:
为什么是4而不是5呢?
在echo之前明明已经把变量a的值改成5了?
让我们先了解一下批处理运行命令的机制:
批处理读取命令时是按行读取的(另外例如for命令等,其后用一对圆括号闭合的所有语句也当作一行),在处理之前要完成必要的预处理工作,这其中就包括对该行命令中的变量赋值。
我们现在分析一下例1,批处理在运行到这句“seta=5&echo%a%”之前,先把这一句整句读取并做了预处理——对变量a赋了值,那么%a%当然就是4了!
(没有为什么,批处理就是这样做的。
)
而为了能够感知环境变量的动态变化,批处理设计了变量延迟。
简单来说,在读取了一条完整的语句之后,不立即对该行的变量赋值,而会在某个单条语句执行之前再进行赋值,也就是说“延迟”了对变量的赋值。
那么如何开启变量延迟呢?
变量延迟又需要注意什么呢?
举个例子说明一下:
例2:
@echooff
setlocalenabledelayedexpansion
seta=4
seta=5&echo!
a!
pause
结果:
5
解说:
启动了变量延迟,得到了正确答案。
变量延迟的启动语句是“setlocalenabledelayedexpansion”,并且变量要用一对叹号“!
!
”括起来(注意要用英文的叹号),否则就没有变量延迟的效果。
分析一下例2,首先“setlocalenabledelayedexpansion”开启变量延迟,然后“seta=4”先给变量a赋值为
4,“seta=5&echo!
a!
”这句是给变量a赋值为5并输出(由于启动了变量延迟,所以批处理能够感知到动态变化,即不是先给该行变量赋值,而是在运行过程中给变量赋值,因此此时a的值就是5了)。
再举一个例子巩固一下。
例3:
@echooff
setlocalenabledelayedexpansion
for/l%%iin(1,1,5)do(
seta=%%i
echo!
a!
)
pause
结果:
1
2
3
4
5
解说:
本例开启了变量延迟并用“!
!
”将变量扩起来,因此得到我们预期的结果。
如果不用变量延迟会出现什
么结果呢?
结果是这样的:
ECHO处于关闭状态。
ECHO