update_all.bat代码示例:

@echo off

echo ******************************************************************

echo ***************https://home.cnblogs.com/fyc001/*******************

echo ******************************************************************

echo ===================== Update_all Script ==========================

setlocal

set FINANCIAL_PATH=%CD%

set WORKING_PATH=%CD%

echo 请输入版本日期:

set /p VER_DATE=

echo 请输入发布版本号(默认输入01,当天多个版本顺序递增)

set /p VER_NUMBER=

echo 请输入安装数据库SID:

set /p SID=

set USER_NAME=FINANCIAL

set PASSWORD=FINANCIAL

echo ------------------------------------------------------------------

echo 如果以上参数有问题,请按Ctr+c终止操作

pause

cls

cd %FINANCIAL_PATH%

echo db_%VER_DATE%%VER_NUMBER%.sql

set INSCRIPT=db_%VER_DATE%%VER_NUMBER%_corporation.txt

for /f %%i in (%INSCRIPT%) do (

echo -----------------------------------------------------------------

echo 开始安装%%i_%USER_NAME%增量版本,如果以上参数有问题,请按Ctr+c终止操作

pause

sqlplus /nolog @run.sql %SID% %%i_%USER_NAME% db_%VER_DATE%%VER_NUMBER%.sql db_%%i_%USER_NAME%_%VER_DATE%%VER_NAME%.log %%i %%i_%PASSWORD%

echo 更新完成,详情请查看"%WORKING_PATH%\db_%%i_%USER_NAME%_%VER_DATE%%VER_NAME%.log"......

notepad %WORKING_PATH%\db_%%i_%USER_NAME%_%VER_DATE%%VER_NAME%.log

)

endlocal

pause

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

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

%variable  指定一个单一字母可替换的参数。

(set)      指定一个或一组文件。可以使用通配符。

command    指定对每个文件执行的命令。

command-parameters              为特定命令指定参数或命令行开关。

在批处理程序中使用 FOR 命令时,指定变量请使用 %%variable 而不要用 %variable。变量名称是区分大小写的,所以 %i 不同于 %I.

如果启用命令扩展,则会支持下列 FOR 命令的其他格式:

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

如果集中包含通配符,则指定与目录名匹配,而不与文件名匹配。

FOR /R [[drive:]path] %variable IN (set) DO command [command-parameters]

检查以 [drive:]path 为根的目录树,指向每个目录中的 FOR 语句。     如果在 /R 后没有指定目录规范,则使用当前目录。如果集仅为一个单点(.)字符,     则枚举该目录树。

FOR /L %variable IN (start,step,end) DO command [command-parameters]

该集表示以增量形式从开始到结束的一个数字序列。因此,(1,1,5)将产生序列     1 2 3 4 5,(5,-1,1)将产生序列(5 4 3 2 1)

FOR /F ["options"] %variable IN (file-set) DO command [command-parameters] FOR /F ["options"] %variable IN ("string") DO command [command-parameters] FOR /F ["options"] %variable IN ('command') DO command [command-parameters]

或者,如果有 usebackq 选项:

FOR /F ["options"] %variable IN (file-set) DO command [command-parameters] FOR /F ["options"] %variable IN ("string") DO command [command-parameters] FOR /F ["options"] %variable IN ('command') DO command [command-parameters]

fileset 为一个或多个文件名。继续到 fileset 中的下一个文件之前,     每份文件都被打开、读取并经过处理。处理包括读取文件,将其分成一行行的文字,     然后将每行解析成零或更多的符号。然后用已找到的符号字符串变量值调用 For 循环。     以默认方式,/F 通过每个文件的每一行中分开的第一个空白符号。跳过空白行。     您可通过指定可选 "options" 参数替代默认解析操作。这个带引号的字符串包括一个     或多个指定不同解析选项的关键字。这些关键字为:

eol=c           - 指一个行注释字符的结尾(就一个)

skip=n          - 指在文件开始时忽略的行数。

delims=xxx      - 指分隔符集。这个替换了空格和跳格键的

默认分隔符集。

tokens=x,y,m-n  - 指每行的哪一个符号被传递到每个迭代

的 for 本身。这会导致额外变量名称的分配。m-n

格式为一个范围。通过 nth 符号指定 mth。如果

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

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

分配并接受行的保留文本。

usebackq        - 指定新语法已在下类情况中使用:

在作为命令执行一个后引号的字符串并且一个单

引号字符为文字字符串命令并允许在 file-set

中使用双引号扩起文件名称。

某些范例可能有助:

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 分析逻辑,方法是,     用单引号将括号之间的 file-set 括起来。这样,该字符     串会被当作一个文件中的一个单一输入行进行解析。

最后,可以用 FOR /F 命令来分析命令的输出。方法是,将     括号之间的 file-set 变成一个反括字符串。该字符串会     被当作命令行,传递到一个子 CMD.EXE,其输出会被捕获到     内存中,并被当作文件分析。如以下例子所示:

FOR /F "usebackq delims==" %i IN (`set`) DO @echo %i

会枚举当前环境中的环境变量名称。

另外,FOR 变量参照的替换已被增强。您现在可以使用下列 选项语法:

%~I          - 删除任何引号("),扩展 %I

%~fI        - 将 %I 扩展到一个完全合格的路径名

%~dI        - 仅将 %I 扩展到一个驱动器号

%~pI        - 仅将 %I 扩展到一个路径

%~nI        - 仅将 %I 扩展到一个文件名

%~xI        - 仅将 %I 扩展到一个文件扩展名

%~sI        - 扩展的路径只含有短名

%~aI        - 将 %I 扩展到文件的文件属性

%~tI        - 将 %I 扩展到文件的日期/时间

%~zI        - 将 %I 扩展到文件的大小

%~$PATH:I   - 查找列在路径环境变量的目录,并将 %I 扩展

到找到的第一个完全合格的名称。如果环境变量名

未被定义,或者没有找到文件,此组合键会扩展到

空字符串

可以组合修饰符来得到多重结果:

%~dpI       - 仅将 %I 扩展到一个驱动器号和路径

%~nxI       - 仅将 %I 扩展到一个文件名和扩展名

%~fsI       - 仅将 %I 扩展到一个带有短名的完整路径名

%~dp$PATH:I - 搜索列在路径环境变量的目录,并将 %I 扩展

到找到的第一个驱动器号和路径。

%~ftzaI     - 将 %I 扩展到类似输出线路的 DIR

在以上例子中,%I 和 PATH 可用其他有效数值代替。%~ 语法 用一个有效的 FOR 变量名终止。选取类似 %I 的大写变量名 比较易读,而且避免与不分大小写的组合键混淆。

有关dos变量引用的链接:http://m.jb51.net/article/49198.htm

链接来自网络,如有侵权,请联系本人删除

Windowns DOS For 循环实例的更多相关文章

  1. dos下循环复制一张图片的bat

    @echo off setlocal enabledelayedexpansion ,,) do ( @echo !dm! copy .png !dm!.png ) 我期待的结果是将140041.pn ...

  2. python3.4学习笔记(十) 常用操作符,条件分支和循环实例

    python3.4学习笔记(十) 常用操作符,条件分支和循环实例 #Pyhon常用操作符 c = d = 10 d /= 8 #3.x真正的除法 print(d) #1.25 c //= 8 #用两个 ...

  3. 【转载】恢复误删文件--DOS命令应用实例(一)

    <电脑爱好者>报转载第一辑第二篇之恢复误删文件--DOS命令应用实例(一)                             恢复误删文件--DOS命令应用实例(一) 上期我们讲述了 ...

  4. python3速查参考- python基础 3 -> -> while循环实例 + Continue && break的应用 + 列表的初步学习

    while语句的应用 实例如下: """ 述求:用户登录系统,最多只能登录三次 第三次失败后,程序终止 """ user_table = { ...

  5. JavaScript循环实例

    几个经典的循环案例: 1.一张纸的厚度是0.0001米,将纸对折,对折多少次厚度超过珠峰高度8848米 var i=0; var h=0.0001; while(true){ i++; h=h*2; ...

  6. 【JavaScript for循环实例】

    1.大马驮2石粮食,中马驮1石粮食,两头小马驮一石粮食,要用100匹马,驮100石粮食,该如何调配? //驮100石粮食,大马需要50匹 for(var a=0;a<=50;a++){ //驮1 ...

  7. for循环实例

    for循环“池理解”[root@localhost ~]# vi showday.sh#!/bin/bashfor TM in "Morning" "Noon" ...

  8. php do while循环实例

    do-while循环和while循环非常相似,其区别只是在于do-while保证必须执行一次,而while在表达式不成立时则可能不做任何操作. do-while 循环只有一种语法: do { stat ...

  9. Python基本循环实例Day 1

    输入正确的用户名和密码,显示登陆界面,超过三次输入错误则锁定,定义字符串记得加上单引号,数字可以int定义,while循环和if循环语句后加上:,break不加: print("------ ...

随机推荐

  1. python's fifteenth day for me 递归函数

    递归... def age(n): if n == 1: return 18 else: return age(n-1)+2 # 反复调用函数age() print(age(4)) l = [1,3, ...

  2. mysql忘记root密码的处理方法

    在linux下,如果忘记了mysql中root用户的密码可以采用以下办法解决. 1. 修改my.cnf,加入skip-grant-tables 修改mysql的配置文件my.cnf,在[mysqld] ...

  3. OSCache-缓存过滤器CacheFilter

    用CashFilter实现页面级缓存. 在OSCache组件中提供了一个CacheFilter用于实现页面级的缓存,主要用于对web应用中的某些动态页面进行缓存,尤其是那些需要生成pdf格式文件/报表 ...

  4. 用C/C++扩展你的PHP

    PHP取得成功的一个主要原因之一是她拥有大量的可用扩展.web开发者无论有何种需求,这种需求最有可能在PHP发行包里找到.PHP发行包包括支持各种数据库,图形文件格式,压缩,XML技术扩展在内的许多扩 ...

  5. 使用FileReader与FileWriter读写数据

    -------------siwuxie095                         工程名:TestFileRW 包名:com.siwuxie095.filerw 类名:FileReade ...

  6. python中Dict与OrderedDict

    使用dict时,Key是无序的.在对dict做迭代时,我们无法确定Key的顺序. 如果要保持Key的顺序,可以用OrderedDict: from collections import Ordered ...

  7. SpringBoot26 利用 Ribbon + RestTemplate 调用远程服务资源

    1 RestTemplate扫盲 借助 RestTemplate,Spring应用能够方便地使用REST资源  2 准备 创建三个springCloud项目 >Eureaka : 服务注册中心 ...

  8. Angular26 ng-content和ng-container、投影的使用

    1 准备工作 1.1 搭建angular环境 技巧01:本博文基于angular5 1.3 创建一个angular项目 技巧01:根据业务划分模块,每个模块都设定一个主组件 技巧02:利用路由实现模块 ...

  9. mybatis 框架 的应用之二(批量添加、实现分页查询)

    lf-driver=com.mysql.jdbc.Driver lf-url=jdbc:mysql://localhost:3306/test lf-user=LF lf-password=LF &l ...

  10. oracle获取表和列的备注

    using System;using System.Collections.Generic;using System.Data;using System.Linq;using System.Runti ...