bat 文件语法

完整教程参考

https://www.w3cschool.cn/dosmlxxsc1/ipzxrj.html

 

常用命令 

echo、@、call、pause、rem(小技巧:用::代替rem)是批处理文件最常用的几个命令。 

 

(1) echo 表示显示此命令后的字符 ,echo off 表示在此语句后所有运行的命令都不显示命令行本身

(2)@与echo off相像,但它是加在每个命令行的最前面,表示运行时不显示这一行的命令行(只能影响当前行)。 

(3)call 调用另一个批处理文件(如果不用call而直接调用别的批处理文件,那么执行完那个批处理文件后将无法返回当前文件并执行当前文件的后续命令)。 

(4)pause 运行此句会暂停批处理的执行并在屏幕上显示Press any key to continue...的提示,等待用户按任意键后继续 

(5)rem 表示此命令后的字符为解释行(注释),不执行,只是给自己今后参考用的(相当于程序中的注释ge,两个冒号也可以表示注释)。

(6)type  取出文件的内容eg: type 1.txt 也可以使用 type 文件 | findstr /I 关键字 来获取含有关键字信息的部分内容,其中的 /I 表示忽略关键字字母的大小写。

基础补充:

(1)%1  表示取执行时传进来的第一个参数

(2)set key=!key:~1!   其中    !key:~1!    这个是去掉key值的第一个字符   

(3)for /f命令之—Delims和Tokens用法&总结_别逗了好么-CSDN博客_delims

就好比文本是这样的内容

MAIL_BATCH_DATE=20200201

MAIL_BATCH_CNT=120

delims是定义分割符,这个文本里面的东西用啥去切分

tokens是切分之后去拿哪些数据,1,2就是切开之后1和2列的数据都拿出来

for /f "delims== tokens=1,2" %%i in (%log_path%\osql.log) do (
set key=%%i
if !key!==MAIL_BATCH_DATE set MAIL_DATE=%%j
if !key!==MAIL_BATCH_CNT set MAIL_CNT=%%j
)
DEL /f %log_path%\osql.log

 

特殊命令  

if  、goto、 choice、  for是批处理文件中比较高级的命令。

 

一、if 是条件语句,用来判断是否符合规定的条件,从而决定执行不同的命令。有三种格式: 
 
1、if [not] "参数" == "字符串"  待执行的命令 
参数如果等于(not表示不等,下同)指定的字符串,则条件成立,运行命令,否则运行下一句。 例:if "%1"=="a" format a: 
 
2、if [not] exist [路径\]文件名 待执行的命令 
如果有指定的文件,则条件成立,运行命令,否则运行下一句。 如: if exist c:\config.sys type c:\config.sys  表示如果存在c:\config.sys文件,则显示它的内容。 
 
3、if errorlevel <数字> 待执行的命令 
很多DOS程序在运行结束后会返回一个数字值用来表示程序运行的结果(或者状态),通过if errorlevel命令可以判断程序的返回值,根据不同的返回值来决定执行不同的命令(返回值必须按照从大到小的顺序排列)。如果返回值等于指定的数字,则条件成立,运行命令,否则运行下一句。 如if errorlevel 2 goto x2 
 

二、goto 批处理文件运行到这里将跳到goto所指定的标号(标号即label,标号用:后跟标准字符串来定义)处,goto语句一般与if配合使用,根据不同的条件来执行不同的命令组。 
 
goto end 
 
:end 
echo this is the end 
 
标号用":字符串"来定义,标号所在行不被执行。 
 
三、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。" 
  
如果我运行命令:CHOICE /C YNC /M "确认请按 Y,否请按 N,或者取消请按 C。" 
屏幕上会显示: 
确认请按 Y,否请按 N,或者取消请按 C。 [Y,N,C]? 
   

四、for 循环命令,只要条件符合,它将多次执行同一命令。 语法: 对一组文件中的每一个文件执行某个特定命令。 
FOR %%variable IN (set) DO command [command-parameters] 
 
%%variable    指定一个单一字母可替换的参数。 
(set)      指定一个或一组文件。可以使用通配符。 
command     指定对每个文件执行的命令。 
command-parameters 为特定命令指定参数或命令行开关。 
 
例如一个批处理文件中有一行:  for %%c in (*.bat *.txt) do type %%c   则该命令行会显示当前目录下所有以bat和txt为扩展名的文件的内容。 
 

delims是刀(默认是空格"delims="可以使默认不生效),tokens是叉子,

 

复制代码 代码如下:@echo off :: 去掉字符串头所有的0 :: for /f "delims=0 tokens=*" %%i in ("0009029") do

https://www.10qianwan.com/articledetail/24071.html

 

 

学到这儿,来看看如下的 批处理文件

@echo off
::描述:通过osql命令行工具查询数据库,进行一些自定义监控
::支持:需要osql.exe和MSVCR71.DLL支持,可以放到脚本同级目录
 
:: 进入脚本当前目录
cd "%~dp0"
 
::取得参数
set "Usg=%1"
 
::判断参数
if "%Usg%"=="" goto Example
 
::初始化连接参数
set host="10.172.10.80" 
set db="DBname"
set user="DBuser"
set pd="password"
 
::根据不同的参数执行不同的查询代码(自行调整)
if "%Usg2%"=="monitor1" (
  ::监控1
    set sql="sql语句1") else if "%Usg%"=="monitor2" (
    ::监控2
    set sql="sql语句2" ) else if "%Usg%"=="monitor3" (
    ::监控3
    set sql="sql语句3") else if "%Usg%"=="monitor4" (
    ::监控4
    set sql="sql语句4"
)
::连接数据库并执行查询(此处的for是对查询到的结果做提取,所以需要按照实际情况自行搞定。。)
for /f "skip=2 delims= " %%i in ('osql.exe -S %host% -U %user% -P %pd% -d %db% -Q %sql%') do ( 
    set result=%%i
    goto :result
)
 
::直接不带参数执行将提示用法
:Example
echo Example:
echo=
echo %~nx0 Conditions
echo=
echo ------------------------------
echo Script will auto exit in 5s...
ping -n 5 127.1>nul
exit
 
::输出结果后自动退出
:result
echo %result%

最后附几个 osql.exe 命令的实用参数

-U login_id
 用户登录 ID。登录 ID 区分大小写。
  
-P password
 是用户指定的密码。如果未使用 -P 选项,osql 将提示输入密码。如果在命令提示符的末尾使用 -P 选项而不带密码,osql 使用默认密码 (NULL)。密码区分大小写。
 
-S server_name[\instance_name]
 指定要连接的 Microsoft® SQL Server™ 2000 实例。在该服务器上指定 server_name 以连接到 SQL Server 的默认实例。在该服务器上指定 server_name\instance_name 以连接到一个已命名的 SQL Server 2000 的实例。如果未指定服务器,osql 将连接到本地计算机上的 SQL Server 默认实例。从网络上的远程计算机执行 osql 时,此选项是必需的。
 
-d db_name
 启动 osql 时发出一个 USE db_name 语句。
 
-Q "query"
 执行查询并立即退出 osql。将查询用双引号引起来,将查询中嵌入的任何内容用单引号引起来。
 
-q "query"
 启动 osql 时执行查询,但是在查询完成时不退出 osql。(注意查询语句不应包含 GO)。如果从批处理文件中发出查询,请使用 %variables 或环境 %variables%。
例如: SET table = sysobjects
 osql /q "Select * from %table%"

 

 
以下就是几个常用命令的返回值及其代表的意义: 
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 拷贝过程中写盘错误 
 

 

原文地址: https://www.cnblogs.com/cangqinglang/p/11495901.html

posted @ 2020-09-07 22:49  向日葵呀  阅读(682)  评论(0编辑  收藏  举报