DOS批处理高级教程精选(七)

第六章 if命令讲解编码

最近发现有些朋友一老问IF命令的用法,IF命令我的以为很简单,因此就一直没把发放到新手教学贴里说,如今我给补上一文,但愿对各位"很是BAT的"新手朋友们有所帮助.命令行


如今开始:内存

在CMD使用IF /?打开IF的系统帮助(本身看我就不所有列出来了),咱们会发现IF有3种基本的用法!
执行批处理程序中的条件处理。字符串

IF [NOT] ERRORLEVEL number command
IF [NOT] string1==string2 command
IF [NOT] EXIST filename command数学

NOT               指定只有条件为 false 的状况下, Windows XP 才
                    应该执行该命令。string

ERRORLEVEL number 若是最后运行的程序返回一个等于或大于
                    指定数字的退出编码,指定条件为 true。it

string1==string2 若是指定的文字字符串匹配,指定条件为 true。test

EXIST filename    若是指定的文件名存在,指定条件为 true。变量

command           若是符合条件,指定要执行的命令。若是指定的
                     条件为 FALSE,命令后可跟一个执行 ELSE
                      关键字后的命令的 ELSE 命令。原理

ELSE 子句必须在 IF 以后出如今同一行上。例如:

    IF EXIST filename (
        del filename
    ) ELSE (
        echo filename missing
    )


第一种用法:IF [NOT] ERRORLEVEL number command

这个用法的基本作用是判断上一条命令执行结果的代码,以决定下一个步骤.
通常上一条命令的执行结果代码只有两结果,"成功"用0表示 "失败"用1表示.

举个例子:
@echo off
net user
IF %ERRORLEVEL% == 0 echo net user 执行成功了!
pause

这是个简单判断上条命令是否执行成功.
细心的朋友可能会发现,这个用法和帮助里的用法不太同样,按照帮助里的写法"IF %ERRORLEVEL% == 0 echo net user 执行成功了! "这一句代码应该写成:IF ERRORLEVEL 0 echo net user 执行成功了!
那为何我要写成这样呢?各位本身把代码改掉执行后,就会发现错误了!用这种语法,无论你的上面的命令是否执行成功,他都会认为命令成功了,不知道是BUG仍是本人理解错误...

补充:这不是bug,而是 if errorlevel 语句的特色:当使用 if errorlevel 0 …… 的句式时,它的含义是:若是错误码的值大于或等于0的时候,将执行某个操做;当使用 if %errorlevel%==0 …… 的句式时,它的含义是:若是错误码的值等于0的时候,将执行某操做。由于这两种句式含义的差异,若是使用前一种句式的时候,错误码语句的排列顺序是从大到小排列

%ERRORLEVEL% 这是个系统变量,返回上条命令的执行结果代码! "成功"用0表示 "失败"用1表示. 固然还有其余参数,用的时候基本就这两数字.
通常上一条命令的执行结果代码只有两结果,"成功"用0表示 "失败"用1表示
  这只是通常的状况,实际上,errorlevel返回值能够在0~255之间,好比,xcopy默认的errorlevel值就有5个,分别表示5种执行状态:

退出码 说明
0 文件复制没有错误。
1 if errorlevel 2 echo。
2 用户按 CTRL+C 终止了 xcopy。
4 出现了初始化错误。没有足够的内存或磁盘空间,或命令行上输入了无效的驱动器名称或语法。
5 出现了磁盘写入错误。

要判断上面xcopy命令的5种退出状况,应写成:
if errorlevel 5 echo出现了磁盘写入错误
if errorlevel 4 echo出现了初始化错误
if errorlevel 2 echo用户按 CTRL+C 终止了 xcopy
if errorlevel 1 echo if errorlevel 2 echo
if errorlevel 0 echo文件复制没有错误。
才能正确执行。

补充完毕。


再举几个例子给新手理解
@echo off
net usertest
IF %ERRORLEVEL% == 1 echo net user 执行失败了!
pause

这个是判断上一条命令是否执行失败的

@echo off
set /p var=随便输入个命令:
%var%
if %ERRORLEVEL% == 0 goto yes
goto no
:yes
echo !var! 执行成功了
pause
exit
:no
echo 基本上执行失败了..
pause

这个是根据你输入的命令,自动判断是成功仍是失败了!


在来一个简化版的
@echo off
set /p var=随便输入个命令:
%var%
if %ERRORLEVEL% == 0 (echo %var%执行成功了) ELSE echo %var%执行失败了!
pause

else后面写上执行失败后的操做!

固然我门还能够把if else这样的语句分红几行写出来,使他看上去好看点...
@echo off
set /p var=随便输入个命令:
%var%
if %ERRORLEVEL% == 0 (
   echo !var! 执行成功了
   ) ELSE (
   echo 基本上执行失败了..
   )
pause


这里介绍的两种简写对IF的三种语法均可以套用,不仅仅是在IF [NOT] ERRORLEVEL number command
这种法上才能用


第二种用法:IF [NOT] string1==string2 command

这个呢就是用来比较变量或者字符的值是否是相等的.

例子
@echo off
set /p var=请输入第一个比较字符:
set /p var2=请输入第二个比较字符:
if %var% == %var2% (echo 咱们相等) ELSE echo 咱们不相等
pause

上面这个例子能够判断你输入的值是否是相等,可是你若是输入相同的字符,可是若是其中一个后面打了一个空格,
这个例子仍是会认为相等,如何让有空格的输入不相等呢?咱们在比较字符上加个双引号就能够了.
@echo off
set /p var=请输入第一个比较字符:
set /p var2=请输入第二个比较字符(多输入个空格试试):
if "%var%" == "%var2%" (echo 咱们相等) ELSE echo 咱们不相等
pause

第三种用法:IF [NOT] EXIST filename command

这个就是判断某个文件或者文件夹是否存在的语法

例子
@echo off
if exist "c:\test" (echo 存在文件) ELSE echo 不存在文件
pause

判断的文件路径加引号是为了防止路径有空格,若是路径有空格加个双引号就不会出现判断出错了!

这个语法没什么太多的用法,基本就这样了,就很少介绍了.

另外咱们看到每条IF用法后都有个[NOT]语句,这啥意思?其余加上他的话,就表示先判断咱们的条件不成立时,
没加他默认是先判断条件成立时,好比上面这个例子
@echo off
if not exist "c:\test" (echo 存在文件) ELSE echo 不存在文件
pause

加个NOT,执行后有什么结果,若是你的C盘下根本就没c:\test,他仍是会显示"存在文件",这就表示了加了NOT就
会先判断条件失败!懂了吧,上面例子改为这样就正确了!
@echo off
if not exist "c:\test" (echo 不存在文件) ELSE echo 存在文件
pause


第四种用法:IF加强的用法

IF [/I] string1 compare-op string2 command #参数/I表示不区分大小写
IF CMDEXTVERSION number command
IF DEFINED variable command #判断变量是否存在,颇有用

CMDEXTVERSION 条件的做用跟 ERRORLEVEL 的同样,除了它
是在跟与命令扩展名有关联的内部版本号比较。第一个版本
是 1。每次对命令扩展名有至关大的加强时,版本号会增长一个。
命令扩展名被停用时,CMDEXTVERSION 条件不是真的。

若是已定义环境变量,DEFINED 条件的做用跟 EXISTS 的同样
IF DEFINED variable command
IF NOT "variable"=="" command
上面两条命令效果同样。

用“set variable=”命令使变量variable变成未定义,即空值。

一句话,变量值为空,则为未定义;变量值不为空,则为已定义。
用语句IF DEFINED variable command判断变量是否存在时,请注意variable为不使用引导符号%的变量名,不能用写为%variable%,不然出错。

例:
if defined aa (echo 变量aa存在) else (echo 变量aa不存在)
运行显示:变量aa不存在

例:
set aa=123
set aa=
if defined aa (echo 变量aa存在) else (echo 变量aa不存在)
运行显示:变量aa不存在


例:
@echo off
if a == A (echo 咱们相等) ELSE echo 咱们不相等
pause

执行后会显示:咱们不相等

例:
@echo off
if /i a == A (echo 咱们相等) ELSE echo 咱们不相等
pause


加上/I不区分大小写就相等了!

最后面还有一些用来判断数字的符号

    EQU - 等于
    NEQ - 不等于
    LSS - 小于
    LEQ - 小于或等于
    GTR - 大于
    GEQ - 大于或等于

我就举一个例子,你们都懂数学...不讲多了
@echo off
set /p var=请输入一个数字:
if %var% LEQ 4 (echo 我小于等于4) ELSE echo 我不小于等于4
pause


                                         BY 伤脑筋

----------------------------难明其妙的水宫殿----------------------------土耳其首都伊斯坦布尔是座横跨欧亚的历史名城。来自欧亚非三大洲的各类文化在此交织碰撞,造成了各类文明奇迹,也留下了许多难解的谜题。在伊斯坦布尔郊外的埃列巴坦有座被当地人视为“恶魔之地”的宫殿,传说殿中藏有恶魔。人们从空旷阴森的大殿外走过,每每能听到里面奇怪的哗哗水声,格外玄秘恐怖,没有人敢去探个究竟。直到1920年,一对情侣才在好奇心的驱使下走进了大殿。他们刚刚踏入殿中,忽然一声巨响,地下顿时大水汹涌。两人急忙转身逃出,发现大水已经高出门槛但却并不溢出。转眼之间,水又当即退下,无影无踪。两人鼓足勇气再次走进大殿,才发现这里竟是一座华丽无比的古罗马式厅堂,有高耸雪白的大理石柱、呼之欲出的美丽雕像、繁复优美的高雅壁画。    闻讯而来的考古学家们对宫殿进行了全面的勘查,发现它大约建于公元4世纪左右,有多是东罗马帝国的君士坦丁大帝定都于此后的建筑。殿中的大水涨落极有规律,一昼夜涨落6次,每次都有准确的时间。更奇怪的是宫殿大门之下发现的一堆碎石,它彷佛是控制着水涨水落的闸门。碎石底下是一排空心圆柱,彷佛是引水管道。这座奇怪的建筑是干什么用的呢?有人说是罗马人的蓄水池。那么它为何要建得如此华丽,并且可以控制水位涨落呢?为何大水高过门槛却漫不出来呢?它的工做原理又是什么?????选自《世界未解之谜》

相关文章
相关标签/搜索