zoukankan      html  css  js  c++  java
  • BAT语句:if语句和for语句[转]

    BAT语句:if语句和for语句
    2011-03-15 10:06

    BAT语句结构

      类似于C语言,批处理也有它的语句结构。批处理的语句结构主要有选择结构(if语句)、循环结构(for语句)等。 

    if语句(选择结构)

      if语句实现条件判断,包括字符串比较、存在判断、定义判断等。通过条件判断,if语句即可以实现选择功能。 

      1、字符串比较 

      if语句仅能够对两个字符()是否相同、先后顺序进行判断等。其命令格式为: 

      IF [not] string1 compare-op string2 command1 [else command2] 

      其中,比较操作符compare-op有以下几类: 

      == - 等于 

      EQU - 等于 

      NEQ - 不等于 

      LSS - 小于 

      LEQ - 小于或等于 

      GTR - 大于 

      GEQ - 大于或等于 

      选择开关/i则不区分字符串大小写;选择not项,则对判断结果进行逻辑非。 

      字符串比较示例: 

      =============================================== 

      @echo off 

      set str1=abcd1233 

      set str2=ABCD1234 

      if %str1%==%str2% (echo 字符串相同!) else (echo 字符串不相同!

      if /i %str1% LSS %str2% (echo str1^<str2) else (echo str1^>=str2) 

      echo. 

      set /p choice=是否显示当前时间?(y/n) 

      if /i not %choice% EQU n echo 当前时间是:%date% %time% 

      pause>nul 

      =============================================== 

      对于最后一个if判断,当我们输入nN时的效果是一样的,都不会显示时间。如果我们取消开关/i,则输入N时,依旧会显示时间。 

      另外请注意一下几个细节:1-echo str1^<str2echo str1^>=str22-echo. 

      2、存在判断 

      存在判断的功能是判断文件或文件夹是否存在。其命令格式为: 

      IF [NOT] EXIST filename command1 [else command2] 

      =============================================== 

      @echo off 

      if exist %0 echo 文件%0是存在的! 

      if not exist %~df0 ( 

      echo 文件夹%~df0不存在! 

      ) else echo 文件夹%~df0存在! 

      pause>nul 

      =============================================== 

      这里注意几个地方: 

      1-存在判断既可以判断文件也可以判断文件夹; 

      2-%0即代表该批处理的全称(包括驱动器盘符、路径、文件名和扩展类型) 

      3-%~df0是对%0的修正,只保留了其驱动器盘符和路径,详情请参考for /?,属高级批处理范畴; 

      4-注意if语句的多行书写,多行书写要求command1的左括号必须和if在同一行、else必须和command1的右括号同行、command2的左括号必须与else同行、command1command2都可以有任意多行,即command可以是命令集。 

      3、定义判断 

      定义判断的功能是判断变量是否存在,即是否已被定义。其命令格式为: 

      IF [not] DEFINED variable command1 [else command2] 

      存在判断举例: 

      =============================================== 

      @echo off 

      set var=111 

      if defined var (echo var=%var%) else echo var尚未定义! 

      set var= 

      if defined var (echo var=%var%) else echo var尚未定义! 

      pause>nul 

      =============================================== 

      对比可知,"set var="可以取消变量,收回变量所占据的内存空间。 

    for语句(循环结构)

      for语句可以实现类似于C语言里面的循环结构,当然for语句的功能要更强大一点,通过不同的开关可以实现更多的功能。for语句有多个开关,不同开关将会实现不同的功能。 

      1、无开关 

      无开关的for语句能够对设定的范围内进行循环,是最基本的for循环语句。其命令格式为: 

      FOR %%variable IN (set) DO command 

      其中,%%variable是批处理程序里面的书写格式,在DOS中书写为%variable,即只有一个百分号(%)set就是需要我们设定的循环范围,类似于C语言里面的循环变量;do后面的command就是循环所执行的命令,即循环体。 

      无开关for语句举例: 

      =============================================== 

      @echo off 

      for %%i in (a,"b c",d) do echo %%i 

      pause>nul 

      =============================================== 

      2、开关/L 

       含开关/Lfor语句,可以根据set里面的设置进行循环,从而实现对循环次数的直接控制。其命令格式为: 

      FOR /L %%variable IN (start,step,end) DO command 

      其中,start为开始计数的初始值,step为每次递增的值,end为结束值。当end小于start时,step需要设置为负数。 

      含开关/Lfor语句举例(创建5个文件夹) 

      =============================================== 

      @echo off 

      for /l %%i in (1,2,10) do md %%i 

      pause 

      =============================================== 

      上例将新建5个文件夹,文件夹名称依次为13579。可以发现,%%i的结束值并非end的值10,而是不大于end的一个数。 

      3、开关/F 

      含开关/Ffor语句具有最强大的功能,它能够对字符串进行操作,也能够对命令的返回值进行操作,还可以访问硬盘上的ASCII码文件,比如txt文档等。其命令格式为: 

      FOR /F ["options"] %%variable IN (set) DO command 

      其中,set("string"'command'file-set)中的一个;options(eol=cskip=ndelims=xxxtokens=x,y,m-nusebackq)中的一个或多个的组合。各选项的意义参见for /f。一般情况下,使用较多的是skiptokensdelims三个选项。 

      含开关/Ffor语句举例: 

      =============================================== 

      @echo off 

      echo **No Options: 

      for /f %%a in ("1,2,10") do echo a=%%a 

      echo **Options tokens ^& delims: 

      for /f "tokens=1-3 delims=," %%a in ("1,2,10") do echo a=%%a b=%%b c=%%c 

      pause 

      =============================================== 

      @echo off 

      echo 本文件夹里面的文件有: 

      for /f "skip=5 tokens=3* delims= " %%a in ('dir') do ( 

      if not "%%a"=="<DIR>" if not "%%b"=="字节" if not "%%b"=="可用字节" echo %%b 

      

      pause 

      =============================================== 

      @echo off 

      echo 本文件夹里面的文件有: 

      dir>c:\file.txt 

      for /f "skip=5 tokens=3* delims= " %%a in (c:\file.txt) do ( 

      if not "%%a"=="<DIR>" if not "%%b"=="字节" if not "%%b"=="可用字节" echo %%b 

      

      del c:\file.txt 

      pause 

      =============================================== 

      对于后面的两个例子,其中options里面的delims= 是可以删除的,因为只要添加了/F开关系统就将delims的值默认为空格。 

      符号字符串中的最后一个字符星号, 

      那么额外的变量将在最后一个符号解析之后 

      分配并接受行的保留文本。本例中也可以改为4,不过文件名中有空格的文件,只能显示空格以前部分 

      同时我们也看到了,for语句的do后面的command也是可以分行的,只需要保证command的左括号和do在同一行就可以了。 

      4、开关/D/R 

      含开关/D/Rfor语句是与目录或文件有关的命令,一般情况下很少使用。含开关/R的命令有时候被用于通过遍历文件夹来查找某一个文件或文件夹,故而列举此例。 

      含开关/Rfor语句举例(文件夹遍历) 

      =============================================== 

      @echo off 

      setlocal enabledelayedexpansion 

      FOR /R d: %%i IN (.) DO ( 

      set dd=%%i 

      set "dd=!dd:~0,-1!" 

      echo !dd! 

      

      pause 

      exit 

      =============================================== 

      上例即可以罗列出D盘下的所有文件夹,其速度要比命令"tree d:"慢多了,不过其返回结果的实用性则远远超过了tree命令。 

      一般情况下我们不推荐通过遍历文件夹来查找文件,特别是在查找某些程序(比如QQ.exe)的位置时。推荐通过reg命令查找注册表来查找QQ的路径,以保证查找效率。 

      上例中也出现了几个新面孔,如setlocal、感叹号等。其中,感叹号其实就是变量百分号(%)的强化版。之所以要用!而不用%,是因为在for循环中,当一个变量被多次赋值时,%dd%所获取的仅仅是dd第一次被赋予的值;要想刷新dd的值,就必须首先通过命令"setlocal enabledelayedexpansion"来开启延迟变量开关,然后用!dd!来获取dd的值。 

      for语句是批处理里面功能最强大、使用最普遍却又最难掌握的一套命令,这也是批处理菜鸟和批处理高手最明显的一个分水岭,一旦掌握了这套命令,那么你就离批处理达人不远了!

     

    应用:

     

    保存最近五次内数据,将以下内容保存为BAT文件

    echo 在e:\数据库日备份目录下创建tmp,a,b,c,d,e目录

    @echo off
    echo 开始备份数据库.....
    set filename=e:\数据库日备份\tmp\%date:~0,10%
    expuserid=pip_sx_sys/sx@pip132file=%filename%pipsys.dmp wner=pip_sx_sys INDEXES=y grants=y  constraints=y compress=y log=%filename%pipsys.log
    echo 备份结束


    if not exist %filename%fgysuser.dmp goto finish
    del/q e:\数据库日备份\e
    move e:\数据库日备份\d\*.* e:\数据库日备份\e
    move e:\数据库日备份\c\*.* e:\数据库日备份\d
    move e:\数据库日备份\b\*.* e:\数据库日备份\c
    move e:\数据库日备份\a\*.* e:\数据库日备份\b
    move e:\数据库日备份\tmp\*.* e:\数据库日备份\a
    :finish

    在BAT里执行ORACLE的SQL语句

    建个一个BAT文件写入以下语句:

    sqlplusetms/12@orcl15@runSql.sql

    在 runSql.sql文件输入以下内容

    connetms/12@orcl15   
    alter table AA add a4 varchar2(10);
    commit;
    exit

  • 相关阅读:
    duplicate symbols for architeture arm64 linker command failed with code 1(use-c to see invocation)
    Operation not permitted
    [笔试]常考算法
    过滤ST/退市股票
    python动态调用函数
    dataFrame 切片操作
    DataFrame概念与创建
    DataFrame 加减乘除
    DataFrame查找
    DataFrame操作
  • 原文地址:https://www.cnblogs.com/kelin1314/p/2067697.html
Copyright © 2011-2022 走看看