mysql 在cmd命令行下操作遇到的转义字符

您所在的位置:网站首页 mysql转义字符大全 mysql 在cmd命令行下操作遇到的转义字符

mysql 在cmd命令行下操作遇到的转义字符

2024-07-16 20:01| 来源: 网络整理| 查看: 265

今天在cmd命令行下,用mysqldump来进行备份数据库,遇到了这个一个问题,

先看命令如下,  mysqldump -uyaner -pyaner&123 -h 192.168.0.5 test dbtest.sql

其中'&'字符在cmd下是特殊字符, 所以得用‘^’来进行转义,应该写成如下   

       mysqldump -uyaner -pyaner^&123 -h 192.168.0.5 test dbtest.sql

 

貌似也可以使用mysqldump -uyaner -p“yaner&123 -h 192.168.0.5  test dbtest.sql                      这个还不确定,需验证 

转义时,^^代表^,^|代表|,^"代表"等等

==========================下面是参考的文章============================

原文地址: http://www.douban.com/group/topic/18388207/

目录 第一章 批处理基础 第一节 常用批处理内部命令简介 1、REM 和 :: 2、ECHO 和 @ 3、PAUSE 4、ERRORLEVEL 5、TITLE 6、COLOR 7、mode 配置系统设备 8、GOTO 和 : 9、FIND 10、START 11、assoc 和 ftype 12、pushd 和 popd 13、CALL 14、shift 15、IF 16、setlocal 与 变量延迟 (ENABLEDELAYEDEXPANSION / DISABLEDELAYEDEXPANSION 启动或停用延缓环境变量扩展名。) 17、ATTRIB 显示或更改文件属性 第二节 常用特殊符号 1、@ 命令行回显屏蔽符 2、% 批处理变量引导符 3、> 重定向符 4、>> 重定向符 5、&、 tmp.txt Rem 下行先保存当前目录,再将c:\windows设为当前目录 pushd c:\windows Call :sub tmp.txt Rem 下行恢复前次的当前目录 Popd Call :sub tmp.txt pause Del tmp.txt exit :sub Echo 删除引号: %~1 Echo 扩充到路径: %~f1 Echo 扩充到一个驱动器号: %~d1 Echo 扩充到一个路径: %~p1 Echo 扩充到一个文件名: %~n1 Echo 扩充到一个文件扩展名: %~x1 Echo 扩充的路径指含有短名: %~s1 Echo 扩充到文件属性: %~a1 Echo 扩充到文件的日期/时间: %~t1 Echo 扩充到文件的大小: %~z1 Echo 扩展到驱动器号和路径:%~dp1 Echo 扩展到文件名和扩展名:%~nx1 Echo 扩展到类似 DIR 的输出行:%~ftza1 Echo. Goto :eof 例: set aa=123456 set cmdstr=echo %aa% call %cmdstr% pause 本例中如果不用call,而直接运行%cmdstr%,将显示结果%aa%,而不是123456 14、shift 更改批处理文件中可替换参数的位置。 SHIFT [/n]如果命令扩展名被启用,SHIFT 命令支持/n 命令行开关;该命令行开关告诉 命令从第 n 个参数开始移位;n 介于零和八之间。例如: SHIFT /2 会将 %3 移位到 %2,将 %4 移位到 %3,等等;并且不影响 %0 和 %1。 15、IF IF 条件判断语句,语法格式如下: IF [NOT] ERRORLEVEL number command IF [NOT] string1==string2 command IF [NOT] EXIST filename command 下面逐一介绍,更详细的分析请看后面章节。 (1) IF [NOT] ERRORLEVEL number command IF ERRORLEVEL这个句子必须放在某一个命令的后面,执行命令后由IF ERRORLEVEL 来判断命令的返回值。 Number的数字取值范围0~255,判断时值的排列顺序应该由大到小。返回的值大于等于指定的值时,条件成立 例: @echo off dir c: rem退出代码为>=1就跳至标题1处执行,>=0就跳至标题0处执行 IF ERRORLEVEL 1 goto 1 IF ERRORLEVEL 0 goto 0 Rem 上面的两行不可交换位置,否则失败了也显示成功。 :0 echo 命令执行成功! Rem 程序执行完毕跳至标题exit处退出 goto exit :1 echo 命令执行失败! Rem 程序执行完毕跳至标题exit处退出 goto exit :exit pause 运行显示:命令执行成功! (2) IF [NOT] string1==string2 command string1和string2都为字符的数据,英文内字符的大小写将看作不同,这个条件中的等于号必须是两个(绝对相等的意思) 条件相等后即执行后面的command 检测当前变量的值做出判断,为了防止字符串中含有空格,可用以下格式 if [NOT] {string1}=={string2} command if [NOT] [string1]==[string2] command if [NOT] "string1"=="string2" command 这种写法实际上将括号或引号当成字符串的一部分了,只要等号左右两边一致就行了,比如下面的写法就不行: if {string1}==[string2] command (3) IF [NOT] EXIST filename command EXIST filename为文件或目录存在的意思 echo off IF EXIST autoexec.bat echo 文件存在! IF not EXIST autoexec.bat echo 文件不存在! 这个批处理大家可以放在C盘和D盘分别执行,看看效果 16、setlocal 与 变量延迟 本条内容引用[英雄出品]的批处理教程: 要想进阶,变量延迟是必过的一关!所以这一部分希望你能认真看。 为了更好的说明问题,我们先引入一个例子。 例1: @echo off set a=4 set a=5 & echo %a% pause 结果:4 解说:为什么是4而不是5呢?在echo之前明明已经把变量a的值改成5了? 让我们先了解一下批处理运行命令的机制: 批处理读取命令时是按行读取的(另外例如for命令等,其后用一对圆括号闭合的所有语句也当作一行),在处理之前要完成必要的预处理工作,这其中就包括对该行命令中的变量赋值。我们现在分析一下例1,批处理在运行到这句“set a=5 & echo %a%”之前,先把这一句整句读取并做了预处理——对变量a赋了值,那么%a%当然就是4了!(没有为什么,批处理就是这样做的。) 而为了能够感知环境变量的动态变化,批处理设计了变量延迟。简单来说,在读取了一条完整的语句之后,不立即对该行的变量赋值,而会在某个单条语句执行之前再进行赋值,也就是说“延迟”了对变量的赋值。 那么如何开启变量延迟呢?变量延迟又需要注意什么呢?举个例子说明一下: 例2: @echo off setlocal enabledelayedexpansion set a=4 set a=5 & echo !a! pause 结果:5 解说:启动了变量延迟,得到了正确答案。变量延迟的启动语句是“setlocal enabledelayedexpansion”,并且变量要用一对叹号“!!”括起来(注意要用英文的叹号),否则就没有变量延迟的效果。 分析一下例2,首先“setlocal enabledelayedexpansion”开启变量延迟,然后“set a=4”先给变量a赋值为 4,“set a=5 & echo !a!”这句是给变量a赋值为5并输出(由于启动了变量延迟,所以批处理能够感知到动态变化,即不是先给该行变量赋值,而是在运行过程中给变量赋值,因此此时a的值就是5了)。 再举一个例子巩固一下。 例3: @echo off setlocal enabledelayedexpansion for /l %%i in (1,1,5) do ( set a=%%i echo !a! ) pause 结果: 1 2 3 4 5 解说:本例开启了变量延迟并用“!!”将变量扩起来,因此得到我们预期的结果。如果不用变量延迟会出现什 么结果呢?结果是这样的: ECHO 处于关闭状态。 ECHO 处于关闭状态。 ECHO 处于关闭状态。 ECHO 处于关闭状态。 ECHO 处于关闭状态。 即没有感知到for语句中的动态变化。 提示:在没有开启变量延迟的情况下,某条命令行中的变量改变,必须到下一条命令才能体现。这一点也可以加以利用,看例子。 例:交换两个变量的值,且不用中间变量 @echo off ::目的:交换两个变量的值,但是不使用临时变量 ::Code by JM 2007-1-24 [email=CMD@XP]CMD@XP::出处:http://www.cn-dos.net/forum/viewthread.php?tid=27078 set var1=abc set var2=123 echo 交换前: var1=%var1% var2=%var2% set var1=%var2%& set var2=%var1% echo 交换后: var1=%var1% var2=%var2% pause 17、ATTRIB 显示或更改文件属性 ATTRIB [+R|-R] [+A|-A] [+S|-S] [+H|-H] [[drive:] [path] filename] [/S [/D]] + 设置属性。 - 清除属性。 R 只读文件属性。 A 存档文件属性。 S 系统文件属性。 H 隐藏文件属性。 [drive:][path][filename] 指定要处理的文件属性。 /S 处理当前文件夹及其子文件夹中的匹配文件。 /D 也处理文件夹。 例: md autorun attrib +a +s +h autorun 上面的命令将建立文件夹autorun,然后将其设为存档、系统、隐藏属性 -------------------------------------------------------------------------------- 作者: weasel 经验值:1782 发言:487 回复:591 写信 发表于:2008_12_28 AM 01:56 回贴:3 回  复:第二节常用特殊符号 第二节 常用特殊符号 1、@ 命令行回显屏蔽符 2、% 批处理变量引导符 3、> 重定向符 4、>> 重定向符 5、&、 重定向符 输出重定向命令 这个字符的意思是传递并且覆盖,他所起的作用是将运行的结果传递到后面的范围(后边可以是文件,也可以是默认的系统控制台) 在NT系列命令行中,重定向的作用范围由整个命令行转变为单个命令语句,受到了命令分隔符&,&&,||和语句块的制约限制。 比如: 使用命令:echo hello >1.txt将建立文件1.txt,内容为”hello “(注意行尾有一空格) 使用命令:echo hello>1.txt将建立文件1.txt,内容为”hello“(注意行尾没有空格) 4、>> 重定向符 输出重定向命令 这个符号的作用和>有点类似,但他们的区别是>>是传递并在文件的末尾追加,而>是覆盖 用法同上 同样拿1.txt做例子 使用命令: echo hello > 1.txt echo world >>1.txt 这时候1.txt 内容如下: hello world 5、&、nul 表示禁止输出正确的信息 2>nul 表示禁止输出错误信息。 其中的1与2都是代表某个数据流输入输出的地址(NT CMD 称之为句柄,MSDOS称之为设备)。 句柄0:标准输入stdin,键盘输入 句柄1:标准输出stdout,输出到命令提示符窗口(console,代码为CON) 句柄2:标准错误stderr,输出到命令提示符窗口(console,代码为CON) 其中的stdin可被、>>重定向。 我们已经知道读取文本中的内容可以用for命令,但如果只需要读取第一行用for命令就有点麻烦。简单的办法如下: @echo off set /p str=1.txt 结果则是:test > 1.txt 他没有追加在1.txt里,呵呵。只是显示了出来 另外,此转义字符还可以用作续行符号。 举个简单的例子: @echo off echo 英雄^ 是^ 好^ 男人 pause 不用多说,自己试一下就明白了。 为什么转义字符放在行尾可以起到续行符的作用呢?原因很简单,因为每行末尾还有一个看不见的符号,即回车符,转义字符位于行尾时就让回车符失效了,从而起到了续行的作用。 8、& 组合命令 语法:第一条命令 & 第二条命令 [& 第三条命令...]&、&&、||为组合命令,顾名思义,就是可以把多个命令组合起来当一个命令来执行。这在批处理脚本里是允许的,而且用的非常广泛。因为批处理认行不认命令数目。 这个符号允许在一行中使用2个以上不同的命令,当第一个命令执行失败了,也不影响后边的命令执行。 这里&两边的命令是顺序执行的,从前往后执行。 比如: dir z:\ & dir y:\ & dir c:\ 以上命令会连续显示z,y,c盘的内容,不理会该盘是否存在 9、&& 组合命令 语法:第一条命令 && 第二条命令 [&& 第三条命令...]用这种方法可以同时执行多条命令,当碰到执行出错的命令后将不执行后面的命令,如果一直没有出错则一直执行完所有命令 这个命令和上边的类似,但区别是,第一个命令失败时,后边的命令也不会执行 dir z:\ && dir y:\ && dir c:\ 10、|| 组合命令 语法:第一条命令 || 第二条命令 [|| 第三条命令...]用这种方法可以同时执行多条命令,当一条命令失败后才执行第二条命令,当碰到执行正确的命令后将不执行后面的命令,如果没有出现正确的命令则一直执行完所有命令; 提示:组合命令和重定向命令一起使用必须注意优先级 管道命令的优先级高于重定向命令,重定向命令的优先级高于组合命令 问题:把C盘和D盘的文件和文件夹列出到a.txt文件中。看例: dir c:\ && dir d:\ > a.txt 这样执行后a.txt里只有D盘的信息!为什么?因为组合命令的优先级没有重定向命令的优先级高!所以这句在执行时将本行分成这两部分:dir c:\和dir d:\ > a.txt,而并不是如你想的这两部分:dir c:\ && dir d:\和> a.txt。要使用组合命令&&达到题目的要求,必须得这么写: dir c:\ > a.txt && dir d:\ >> a.txt 这样,依据优先级高低,DOS将把这句话分成以下两部分:dir c:\ > a.txt和dir d:\ >> a.txt。例十八中的几句的差别比较特殊,值得好好研究体会一下。 当然这里还可以利用&命令(自己想一下道理哦): dir c:\ > a.txt & dir d:\ >> a.txt 11、"" 字符串界定符 双引号允许在字符串中包含空格,进入一个特殊目录可以用如下方法 cd "program files" cd progra~1 cd pro* 以上三种方法都可以进入program files这个目录 12、, 逗号 逗号相当于空格,在某些情况下“,”可以用来当做空格使 比如 dir,c:\ 13、; 分号 分号,当命令相同时,可以将不同目标用;来隔离,但执行效果不变,如执行过程中发生错误,则只返回错误报告,但程序仍会执行。(有人说不会继续执行,其实测试一下就知道了) 比如: dir c:\;d:\;e:\;z:\ 以上命令相当于 dir c:\ dir d:\ dir e:\ dir f:\ 如果其中z盘不存在,运行显示:系统找不到指定的路径。然后终止命令的执行。 例:dir c:\;d:\;e:\1.txt 以上命令相当于 dir c:\ dir d:\ dir e:\1.txt 其中文件e:\1.txt不存在,但e盘存在,有错误提示,但命令仍会执行。 为什么?如果目标路径不存在,则终止执行;如果路径存在,仅文件不存在,则继续执行。 14、() 括号 小括号在批处理编程中有特殊的作用,左右括号必须成对使用,括号中可以包括多行命令,这些命令将被看成一个整体,视为一条命令行。 括号在for语句和if语句中常见,用来嵌套使用循环或条件语句,其实括号()也可以单独使用,请看例子。 例: 命令:echo 1 & echo 2 & echo 3 可以写成: ( echo 1 echo 2 echo 3 ) 上面两种写法效果一样,这两种写法都被视为是一条命令行。 注意:这种多条命令被视为一条命令行时,如果其中有变量,就涉及到变量延迟的问题。 15、! 感叹号 没啥说的,在变量延迟问题中,用来表示变量,即%var%应该表示为!var!,请看前面的setlocal命令介绍。 第二章 DOS循环:for命令详解 讲FOR之前呢,咋先告诉各位新手朋友,如果你有什么命令不懂,直接在CMD下面输入: name /? 这样的格式来看系统给出的帮助文件,比如for /? 就会把FOR命令的帮助全部显示出来!当然许多菜鸟都看不懂....所以才会有那么多批处理文章!!!!俺也照顾菜鸟,把FOR命令用我自己的方式说明下! 正式开始: 一、基本格式 FOR %%variable IN (set) DO command [command-parameters] %%variable 指定一个单一字母表示可替换的参数。 (set) 指定一个或一组文件。可以使用通配符。 command 指定对每个文件执行的命令。 command-parameters 为特定命令指定参数或命令行开关。 参数:FOR有4个参数 /d /l /r /f 他们的作用我在下面用例子解释 现在开始讲每个参数的意思 二、参数 /d FOR /D %%variable IN (set) DO command [command-parameters] 如果集中包含通配符,则指定与目录名匹配,而不与文件 名匹配。 如果 Set (也就是我上面写的 "相关文件或命令") 包含通配符(* 和 ?),将对与 Set 相匹配的每个目录(而不是指定目录中的文件组)执行指定的 Command。 这个参数主要用于目录搜索,不会搜索文件,看这样的例子 @echo off for /d %%i in (c:\*) do echo %%i pause 运行会把C盘根目录下的全部目录名字打印出来,而文件名字一个也不显示! 在来一个,比如我们要把当前路径下文件夹的名字只有1-3个字母的打出来 @echo off for /d %%i in (???) do echo %%i pause 这样的话如果你当前目录下有目录名字只有1-3个字母的,就会显示出来,没有就不显示了 这里解释下*号和?号的作用,*号表示任意N个字符,而?号只表示任意一个字符 知道作用了,给大家个思考题目! @echo off for /d %%i in (window?) do echo %%i pause 保存到C盘下执行,会显示什么呢?自己看吧! 显示:windows /D参数只能显示当前目录下的目录名字,这个大家要注意! 三、参数 /R FOR /R [[drive:]path] %%variable IN (set) DO command [command-parameters] 检查以 [drive:]path 为根的目录树,指向每个目录中的 FOR 语句。如果在 /R 后没有指定目录,则使用当前 目录。如果集仅为一个单点(.)字符,则枚举该目录树。 递归 上面我们知道,/D只能显示当前路径下的目录名字,那么现在这个/R也是和目录有关,他能干嘛呢?放心他比/D强大多了! 他可以把当前或者你指定路径下的文件名字全部读取,注意是文件名字,有什么用看例子! 请注意2点: 1、set中的文件名如果含有通配符(?或*),则列举/R参数指定的目录及其下面的所用子目录中与set相符合的所有文件,无相符文件的目录则不列举。 2、相反,如果set中为具体文件名,不含通配符,则枚举该目录树(即列举该目录及其下面的所有子目录),而不管set中的指定文件是否存在。这与前面所说的单点(.)枚举目录树是一个道理,单点代表当前目录,也可视为一个文件。 例: @echo off for /r c:\ %%i in (*.exe) do echo %%i pause 咱们把这个BAT保存到D盘随便哪里然后执行,我会就会看到,他把C盘根目录,和每个目录的子目录下面全部的EXE文件都列出来了!!!! 例: @echo off for /r %%i in (*.exe) do @echo %%i pause 参数不一样了吧!这个命令前面没加那个C:\也就是搜索路径,这样他就会以当前目录为搜索路径,比如你这个BAT你把他放在d:\test目录下执行,那么他就会把D:\test目录和他下面的子目录的全部EXE文件列出来!!! 例: @echo off for /r c:\ %%i in (boot.ini) do echo %%i pause 运行本例发现枚举了c盘所有目录,为了只列举boot.ini存在的目录,可改成下面这样: @echo off for /r c:\ %%i in (boot.ini) do if exist %%i echo %%i pause 用这条命令搜索文件真不错。。。。。。 这个参数大家应该理解了吧!还是满好玩的命令! 四、参数 /L 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)。 使用迭代变量设置起始值 (Start#),然后逐步执行一组范围的值,直到该值超过所设置的终止值 (End#)。/L 将通过对 Start# 与 End# 进行比较来执行迭代变量。如果 Start# 小于 End#,就会执行该命令。如果迭代变量超过 End#,则命令解释程序退出此循环。还可以使用负的 Step# 以递减数值的方式逐步执行此范围内的值。例如,(1,1,5) 生成序列 1 2 3 4 5,而 (5,-1,1) 则生成序列 (5 4 3 2 1)。语法是: 看着这说明有点晕吧!咱们看例子就不晕了! @echo off for /l %%i in (1,1,5) do @echo %%i pause 保存执行看效果,他会打印从1 2 3 4 5 这样5个数字 (1,1,5)这个参数也就是表示从1开始每次加1直到5终止! 等会晕,就打印个数字有P用...好的满足大家,看这个例子 @echo off for /l %%i in (1,1,5) do start cmd pause 执行后是不是吓了一跳,怎么多了5个CMD窗口,呵呵!如果把那个 (1,1,5)改成 (1,1,65535)会有什么结果,我先告诉大家,会打开65535个CMD窗口....这么多你不死机算你强! 当然我们也可以把那个start cmd改成md %%i 这样就会建立指定个目录了!!!名字为1-65535 看完这个被我赋予破坏性质的参数后,我们来看最后一个参数 五、参数 /F \迭代及文件解析 使用文件解析来处理命令输出、字符串及文件内容。使用迭代变量定义要检查的内容或字符串,并使用各种options选项进一步修改解析方式。使用options令牌选项指定哪些令牌应该作为迭代变量传递。请注意:在没有使用令牌选项时,/F 将只检查第一个令牌。 文件解析过程包括读取输出、字符串或文件内容,将其分成独立的文本行以及再将每行解析成零个或更多个令牌。然后通过设置为令牌的迭代变量值,调用 for 循环。默认情况下,/F 传递每个文件每一行的第一个空白分隔符号。跳过空行。 详细的帮助格式为: 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] 带引号的字符串"options"包括一个或多个 指定不同解析选项的关键字。这些关键字为: eol=c - 指一个行注释字符的结尾(就一个) skip=n - 指在文件开始时忽略的行数。 delims=xxx - 指分隔符集。这个替换了空格和跳格键的 默认分隔符集。 tokens=x,y,m-n - 指每行的哪一个符号被传递到每个迭代 的 for 本身。这会导致额外变量名称的分配。m-n 格式为一个范围。通过 nth 符号指定 mth。如果 符号字符串中的最后一个字符星号, 那么额外的变量将在最后一个符号解析之后 分配并接受行的保留文本。经测试,该参数最多 只能区分31个字段。 usebackq - 使用后引号(键盘上数字1左面的那个键`)。 未使用参数usebackq时:file-set表示文件,但不能含有空格 双引号表示字符串,即"string" 单引号表示执行命令,即'command' 使用参数usebackq时:file-set和"file-set"都表示文件 当文件路径或名称中有空格时,就可以用双引号括起来 单引号表示字符串,即'string' 后引号表示命令执行,即`command` 以上是用for /?命令获得的帮助信息,直接复制过来的。 晕惨了!我这就举个例子帮助大家来理解这些参数! For命令例1:**************************************** @echo off rem 首先建立临时文件test.txt echo ;注释行,这是临时文件,用完删除 >test.txt echo 11段 12段 13段 14段 15段 16段 >>test.txt echo 21段,22段,23段,24段,25段,26段 >>test.txt echo 31段-32段-33段-34段-35段-36段 >>test.txt FOR /F "eol=; tokens=1,3* delims=,- " %%i in (test.txt) do echo %%i %%j %%k Pause Del test.txt 运行显示结果: 11段 13段 14段 15段 16段 21段 23段 24段,25段,26段 31段 33段 34段-35段-36段 请按任意键继续. . . 为什么会这样?我来解释: eol=; 分号开头的行为注释行 tokens=1,3* 将每行第1段,第3段和剩余字段分别赋予变量%%i,%%j,%%k delims=,- (减号后有一空格)以逗号减号和空格为分隔符,空格必须放在最后 For命令例2:**************************************** @echo off FOR /F "eol= delims=" %%i in (test.txt) do echo %%i Pause 运行将显示test.txt全部内容,包括注释行,不解释了哈。 For命令例3:**************************************** 另外/F参数还可以以输出命令的结果看这个例子 @echo off FOR /F "delims=" %%i in ('net user') do @echo %%i pause 这样你本机全部帐号名字就出来了把扩号内的内容用两个单引号引起来就表示那个当命令执行,FOR会返回命令的每行结果,加那个"delims=" 是为了让我空格的行能整行显示出来,不加就只显示空格左边一列! 基本上讲完了FOR的基本用法了...如果你看过FOR的系统帮助,你会发现他下面还有一些特定义的变量,这些我先不讲.大家因该都累了吧!你不累我累啊.... 第三章 FOR命令中的变量 FOR命令中有一些变量,他们的用法许多新手朋友还不太了解,今天给大家讲解他们的用法! 先把FOR的变量全部列出来: ~I - 删除任何引号("),扩展 %I %~fI - 将 %I 扩展到一个完全合格的路径名 %~dI - 仅将 %I 扩展到一个驱动器号 %~pI - 仅将 %I 扩展到一个路径 %~nI - 仅将 %I 扩展到一个文件名 %~xI - 仅将 %I 扩展到一个文件扩展名 %~sI - 扩展的路径只含有短名 %~aI - 将 %I 扩展到文件的文件属性 %~tI - 将 %I 扩展到文件的日期/时间 %~zI - 将 %I 扩展到文件的大小 %~$PATH:I - 查找列在路径环境变量的目录,并将 %I 扩展 到找到的第一个完全合格的名称。如果环境变量名 未被定义,或者没有找到文件,此组合键会扩展到 空字符串 我们可以看到每行都有一个大写字母"I",这个I其实就是我们在FOR带入的变量,我们FOR语句代入的变量名是什么,这里就写什么. 比如:FOR /F %%z IN ('set') DO @echo %%z 这里我们代入的变量名是z那么我们就要把那个I改成z,例如%~fI改为%~fz 至于前面的%~p这样的内容就是语法了! 好开始讲解: 一、 ~I - 删除任何引号("),扩展 %I 这个变量的作用就如他的说明,删除引号! 我们来看这个例子: 首先建立临时文件temp.txt,内容如下 "1111 "2222" 3333" "4444"44 "55"55"55 可建立个BAT文件代码如下: @echo off echo ^"1111>temp.txt echo "2222">>temp.txt echo 3333^">>temp.txt echo "4444"44>>temp.txt echo ^"55"55"55>>temp.txt rem 上面建立临时文件,注意不成对的引号要加转义字符^,重定向符号前不要留空格 FOR /F "delims=" %%i IN (temp.txt) DO echo %%~i pause del temp.txt 执行后,我们看CMD的回显如下: 1111 #字符串前的引号被删除了 2222 #字符串首尾的引号都被删除了 3333" #字符串前无引号,后面的引号保留 4444"44 #字符串前面的引号删除了,而中间的引号保留 55"55"55 #字符串前面的引号删除了,而中间的引号保留 请按任意键继续. . . 和之前temp.txt中的内容对比一下,我们会发现第1、2、5行的引号都消失了,这就是删除引号~i的作用了! 删除引号规则如下(BAT兄补充!) 1、若字符串首尾同时存在引号,则删除首尾的引号; 2、若字符串尾不存在引号,则删除字符串首的引号; 3、如果字符串中间存在引号,或者只在尾部存在引号,则不删除。 龙卷风补充:无头不删,有头连尾删。 二、 %~fI - 将 %I 扩展到一个完全合格的路径名 看例子: 把代码保存放在随便哪个地方,我这里就放桌面吧. FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~fi pause 执行后显示内容如下 C:\Documents and Settings\Administrator\桌面\test.bat C:\Documents and Settings\Administrator\桌面\test.vbs 当我把代码中的 %%~fi直接改成%%i FOR /F "delims==" %%i IN ('dir /b') DO @echo %%i pause 执行后就会显示以下内容: test.bat test.vbs 通过对比,我们很容易就看出没有路径了,这就是"将 %I 扩展到一个完全合格的路径名"的作用 也就是如果%i变量的内容是一个文件名的话,他就会把这个文件所在的绝对路径打印出来,而不只单单打印一个文件名,自己动手动实验下就知道了! 三、 %~dI - 仅将 %I 扩展到一个驱动器号 看例子: 代码如下,我还是放到桌面执行! FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~di pause 执行后我CMD里显示如下 C: C: 我桌面就两个文件test.bat,test.vbs,%%~di作用是,如果变量%%i的内容是一个文件或者目录名,他就会把他这文件 或者目录所在的盘符号打印出来! 四、 %~pI - 仅将 %I 扩展到一个路径 这个用法和上面一样,他只打印路径不打印文件名字 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~pi pause 我就不打结果了,大家自己复制代码看结果吧,下面几个都是这么个用法,代码给出来,大家自己看结果吧! 五、 %~nI - 仅将 %I 扩展到一个文件名 只打印文件名字 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~ni pause 六、 %~xI - 仅将 %I 扩展到一个文件扩展名 只打印文件的扩展名 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~xi pause 七、 %~sI - 扩展的路径只含有短名 打印绝对短文件名 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~si pause 八、 %~aI - 将 %I 扩展到文件的文件属性 打印文件的属性 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~ai pause 九、 %~tI - 将 %I 扩展到文件的日期/时间 打印文件建立的日期 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~ti pause 十、 %~zI - 将 %I 扩展到文件的大小 打印文件的大小 FOR /F "delims==" %%i IN ('dir /b') DO @echo %%~zi pause 上面例子中的"delims=="可以改为"delims=",即不要分隔符 十一、 %~$PATH:I - 查找列在路径环境变量的目录,并将 %I 扩展 到找到的第一个完全合格的名称。如果环境变量名 未被定义,或者没有找到文件,此组合键会扩展到 空字符串 这是最后一个,和上面那些都不一样,我单独说说! 然后在把这些代码保存为批处理,放在桌面。 @echo off FOR /F "delims=" %%i IN ("notepad.exe") DO echo %%~$PATH:i pause 龙卷风补充:上面代码显示结果为C:\WINDOWS\system32\notepad.exe 他的意思就在PATH变量里指定的路径里搜索notepad.exe文件,如果有notepad.exe则会把他所在绝对路径打印出来,没有就打印一个错误! 第四章 批处理中的变量 批处理中的变量,我把他分为两类,分别为"系统变量"和"自定义变量" 我们现在来详解这两个变量! 一、系统变量 他们的值由系统将其根据事先定义的条件自动赋值,也就是这些变量系统已经给他们定义了值, 不需要我们来给他赋值,我们只需要调用而以! 我把他们全部列出来! %ALLUSERSPROFILE% 本地 返回“所有用户”配置文件的位置。 %APPDATA% 本地 返回默认情况下应用程序存储数据的位置。 %CD% 本地 返回当前目录字符串。 %CMDCMDLINE% 本地 返回用来启动当前的 Cmd.exe 的准确命令行。 %CMDEXTVERSION% 系统 返回当前的“命令处理程序扩展”的版本号。 %COMPUTERNAME% 系统 返回计算机的名称。 %COMSPEC% 系统 返回命令行解释器可执行程序的准确路径。 %DATE% 系统 返回当前日期。使用与 date /t 命令相同的格式。由 Cmd.exe 生成。有关 date 命令的详细信息,请参阅 Date。 %ERRORLEVEL% 系统 返回上一条命令的错误代码。通常用非零值表示错误。 %HOMEDRIVE% 系统 返回连接到用户主目录的本地工作站驱动器号。基于主目录值而设置。用 户主目录是在“本地用户和组”中指定的。 %HOMEPATH% 系统 返回用户主目录的完整路径。基于主目录值而设置。用户主目录是在“本地用户和组”中指定的。 %HOMESHARE% 系统 返回用户的共享主目录的网络路径。基于主目录值而设置。用户主目录是 在“本地用户和组”中指定的。 %LOGONSERVER% 本地 返回验证当前登录会话的域控制器的名称。 %NUMBER_OF_PROCESSORS% 系统 指定安装在计算机上的处理器的数目。 %OS% 系统 返回操作系统名称。Windows 2000 显示其操作系统为 Windows_NT。 %PATH% 系统 指定可执行文件的搜索路径。 %PATHEXT% 系统 返回操作系统认为可执行的文件扩展名的列表。 %PROCESSOR_ARCHITECTURE% 系统 返回处理器的芯片体系结构。值:x86 或 IA64 基于 Itanium %PROCESSOR_IDENTFIER% 系统 返回处理器说明。 %PROCESSOR_LEVEL% 系统 返回计算机上安装的处理器的型号。 %PROCESSOR_REVISION% 系统 返回处理器的版本号。 %PROMPT% 本地 返回当前解释程序的命令提示符设置。由 Cmd.exe 生成。 %RANDOM% 系统 返回 0 到 32767 之间的任意十进制数字。由 Cmd.exe 生成。 %SYSTEMDRIVE% 系统 返回包含 Windows server operating system 根目录(即系统根目录) 的驱动器。 %SYSTEMROOT% 系统 返回 Windows server operating system 根目录的位置。 %TEMP% 和 %TMP% 系统和用户 返回对当前登录用户可用的应用程序所使用的默认临时目录。 有些应用程序需要 TEMP,而其他应用程序则需要 TMP。 %TIME% 系统 返回当前时间。使用与 time /t 命令相同的格式。由 Cmd.exe 生成。有关 time 命令的详细信息,请参阅 Time。 %USERDOMAIN% 本地 返回包含用户帐户的域的名称。 %USERNAME% 本地 返回当前登录的用户的名称。 %USERPROFILE% 本地 返回当前用户的配置文件的位置。 %WINDIR% 系统 返回操作系统目录的位置。 这么多系统变量,我们如何知道他的值是什么呢? 在CMD里输入 echo %WINDIR% 这样就能显示一个变量的值了! 举个实际例子,比如我们要复制文件到当前帐号的启动目录里就可以这样 copy d:\1.bat "%USERPROFILE%\「开始」菜单\程序\启动\" %USERNAME% 本地 返回当前登录的用户的名称。 注意有空格的目录要用引号引起来 另外还有一些系统变量,他们是代表一个意思,或者一个操作! 他们分别是%0 %1 %2 %3 %4 %5 ......一直到%9 还有一个%* %0 这个有点特殊,有几层意思,先讲%1-%9的意思. %1 返回批处理的第一个参数 %2 返回批处理的第二个参数 %3-%9依此推类 反回批处理参数?到底怎么个返回法? 我们看这个例子,把下面的代码保存为test.BAT然后放到C盘下 @echo off echo %1 %2 %3 %4 echo %1 echo %2 echo %3 echo %4 进入CMD,输入cd c:\ 然后输入 test.bat 我是第一个参数 我是第二个参数 我是第三个参数 我是第四个参数 注意中间的空格,我们会看到这样的结果: 我是第一个参数 我是第二个参数 我是第三个参数 我是第四个参数 我是第一个参数 我是第二个参数 我是第三个参数 我是第四个参数 对比下代码,%1就是”我是第一个参数” %2就是”我是第二个参数” 怎么样理解了吧! 这些%1和%9可以让批处理也能带参数运行,大大提高批处理功能! 还有一个%* 他是什么呢?他的作用不是很大,只是返回参数而已,不过他是一次返回全部参数的值,不用在输入%1 %2来确定一个个的 例子 @echo off echo %* 同样保存为test.bat 放到C盘 进入CMD,输入cd c:\ 然后输入 test.bat 我是第一个参数 我是第二个参数 我是第三个参数 我是第四个参数 可以看到他一次把全部参数都显示出来了 好现在开始讲那个比较特殊的%0 %0 这个不是返回参数的值了,他有两层意思! 第一层意思:返回批处理所在绝对路径 例子: @echo off echo %0 pause 保存为test.BAT放在桌面运行,会显示如下结果 "C:\Documents and Settings\Administrator\桌面\test.bat" 他把当前批处理执行的所在路经打印出来了,这就是返回批处理所在绝对路径的意思 第二层意思:无限循环执行BAT 例子: @echo off net user %0 保存为BAT执行,他就会无限循环执行net user这条命令,直到你手动停止. 龙卷风补充:其实%0就是第一参数%1前面那个参数,当然就是批处理文件名(包括路径)。 以上就是批处理中的一些系统变量,另外还有一些变量,他们也表示一些功能, FOR命令中的那些就是,FOR变量已经说过,就不讲了. 二、自定义变量 故名思意,自定义变量就是由我们来给他赋予值的变量 要使用自定义变量就得使用set命令了,看例子. @echo off set var=我是值 echo %var% pause 保存为BAT执行,我们会看到CMD里返回一个 "我是值" var为变量名,=号右变的是要给变量的值 这就是最简单的一种设置变量的方法了 如果我们想让用户手工输入变量的值,而不是在代码里指定,可以用用set命令的/p参数 例子: @echo off set /p var=请输入变量的值 echo %var% pause var变量名 =号右边的是提示语,不是变量的值 变量的值由我们运行后自己用键盘输入! -------------------------------------------------------------------------------- 作者: weasel 经验值:1782 发言:487 回复:591 写信 发表于:2008_12_28 AM 01:57 回  复:CMD命令行高级教程精选合编下 CMD命令行高级教程精选合编(下) 第五章 set命令详解 在上一贴中简单的介绍了一下SET设置自定义变量的作用,现在来具体讲一下set的其他功能. 一、用set命令设置自定义变量 显示、设置或删除 cmd.exe 环境变量。 SET [variable]=[string] variable 指定环境变量名。 string 指定要指派给变量的一系列字符串。 要显示当前环境变量,键入不带参数的 SET。 SET 命令不允许变量名含有等号。 注意:以下用法将清除变量variable的值,使其变成未定义状态。 SET variable= 上面等号后面无任何符号,如果写成SET variable="",此时变量值并不为空,而是等于两个引号,即"" 例子: @echo off set var=我是值 echo %var% pause 请看 set var=我是值 ,这就是BAT直接在批处理中设置变量的方法! set 是命令 var是变量名 =号右边的"我是值"是变量的值 在批处理中我们要引用这个变就把var变量名用两个%(百分号)扩起来,如%var% SET还可以提供一个交互界面,让用户自己输入变量的值,然后我们在来根据这个值来做相应操作,现在我就来说说SET的这种语法,只需要加一个"/P"参数就可以了! SET /P variable=[promptString] 例子: @echo off set /p var=请输入变量的值: echo 您输入了 %var% ~_~ pause set /p 是命令语法 var是变量名 =号右边的"请输入变量的值: ",这个是提示语,不是变量的值了! 运行后,我们在提示语后面直接输入1,就会显示一行您输入了 1 ~_~ 现在讲SET其他功能 使用set /?查看SET的帮助我们发现SET除了我上面讲的 SET [variable=[string]]SET /P variable=[promptString]这两种语法外,还有如下几种语法: SET /A expression 环境变量替换已如下增强: %PATH:str1=str2% %PATH:~10,5% %PATH:~-10% %PATH:~0,-2% 这机种语法有什么用处呢?下面来一个个讲解! 二、用set命令进行简单计算 语法:SET /A expression /A 命令行开关指定等号右边的字符串为被评估的数字表达式。该表达式 评估器很简单并以递减的优先权顺序支持下列操作: () -分组 ! ~ - -一元运算符 * / % -算数运算符 + - -算数运算符 > -二进制逻辑移位 & -二进制按位“与” ^ -二进制按位“异” | -二进制按位“或” = *= /= %= += -= -算数赋值 &= ^= |= = -二进制运算赋值 , -表达式分隔符 如果 SET /A 在命令脚本外的命令行执行的,那么它显示该表达式的最后值。 除十六进制有 0x 前缀, 八进制有 0 前缀的,数字值为十进位数字。 因此, 0x12 与 18 和 022相同。请注意八进制公式可能很容易搞混: 08 和 09 是无效的数字,因为 8 和 9 不是有效的八进制位数。 上面这些是系统帮助里的内容,看着是不是有点晕,没关系我来简单解释一下: set的/A参数就是让SET可以支持数学符号进行加减等一些数学运算! 注意:一般的运算常为十进制运算,如果数字字符串最左边为0,将被认为是八进制,从而出错。比如,0812之类的数字不能参与十进制运算,转换方法为:10812-10000 例: set aa=0812 set /a aa=1%aa%-10000 echo %aa% 结果为:812 例: @echo off set /p input=请输入计算表达式: set /a var=%input% echo 计算结果:%input%=%var% pause 上面的例子是龙卷风设计的,很好用哟,请看下面几个运算过程: 注意:DOS计算只能进行整数运算,精确到整数 请输入计算表达式:1+9+20+30-10 计算结果:1+9+20+30-10=50 请按任意键继续. . . 请输入计算表达式:10/3 #除法只能精确到整数 计算结果:10/3=3 请按任意键继续. . . 请输入计算表达式:-100+62 #负数 计算结果:-100+62=-38 请按任意键继续. . . 请输入计算表达式:100%3 #求余数 计算结果:100%3=1 请按任意键继续. . . 注意:以上的求余数运算符%在批处理程序中必须写成%% 请输入计算表达式:(25+75)*2/(15+5) #括号 计算结果:(25+75)*2/(15+5)=10 请按任意键继续. . . 请输入计算表达式:1234567890*9876543210 #范围 无效数字。数字精确度限为 32 位。 计算结果:1234567890*9876543210= 请按任意键继续. . . 注意:上面的计算过程显示,DOS计算只能精确到32位,这个32位是指二进制32位,其中最高位为符号位(0为正,1为负),低位31位为数值。31个1换成十进制为2147483647,所以DOS计算的有效值范围是-2147483648至2147483647,超出该数值范围时计算出错,请看下面的计算过程: 请输入计算表达式:2147483647-1 #最大值减1,值有效 计算结果:2147483647-1=2147483646 请按任意键继续. . . 请输入计算表达式:2147483647+1 #最大值加1,出错,结果为最小值 计算结果:2147483647+1=-2147483648 请按任意键继续. . . 请输入计算表达式:-2147483648-1 #最小值减1,出错,结果为最大值 计算结果:-2147483648-1=2147483647 请按任意键继续. . . 运行set /a a=1+1,b=2+1,c=3+1后会显示一个4,但我们用 echo %a% %b% %c%后看结果,会发现其他数学运算也有效果!,这就是表达式分隔符"逗"号的 作用! 有时候我们需要直接在原变量进行加减操作就可以用这种语法 set /a var+=1 这样的语法对应原始语法就是set /a var = %var% + 1 都是一样的结果,在原变量的值上在进行数学运算,不过这样写简单一点 再来一个: set /a var*=2 其他都这么用,只要帮助里有这个语法! 另外还有一些用逻辑或取余操作符,这些符号,按照上面的使用方法会报错的 比如我们在CMD里输入set /a var=1 & 1 "与运算",他并不会显示为1,而是报错, 为什么?对于这样的"逻辑或取余操作符",我们需要把他们用双引号引起来,也可以用转义字符^,看例子 set /a var= 1 "&" 1 这样结果就显示出来了,其他逻辑或取余操作符用法 set /a var= 1 "+" 1 异运算 set /a var= 1 "%" 1 取模运算 set /a var= 3 ">" 2右移位运算,4的二进制为100,右移动2位为1,结果为1 龙卷风补充:凡是按位计算均需换算成二进制。 思考题:求2的n次方 参考答案: @echo off set /p n=请输入2的几次方: set /a num=1^.bat>.cmd,即如果在同一目录下存在文件名相同的这四类文件,当只键入文件名时,DOS执行的是name.com,如果需要执行其他三个文件,则必须指定文件的全名,如name.bat。 这是一个只有5.43K大小的免费绿色工具,可以运行在纯DOS或DOS窗口的命令行中,用法:Bat2Com FileName,这样就会在同一目录下生成一个名为FileNme.com的可执行文件,执行的效果和原来的.bat文件一样。 九、时间延迟 本条参考引用[英雄]教程 什么是时间延迟?顾名思义,就是执行一条命令后延迟一段时间再进行下一条命令。 延迟的应用见下节:“模拟进度条”。 1、利用ping命令延时 例: @echo off echo 延时前:%time% ping /n 3 127.0.0.1 >nul echo 延时后:%time% pause 解说:用到了ping命令的“/n”参数,表示要发送多少次请求到指定的ip。本例中要发送3次请求到本机的ip(127.0.0.1)。127.0.0.1可简写为127.1。“>nul”就是屏蔽掉ping命令所显示的内容。 2、利用for命令延时 例: @echo off echo 延时前:%time% for /l %%i in (1,1,5000) do echo %%i>nul echo 延时后:%time% pause 解说:原理很简单,就是利用一个计次循环并屏蔽它所显示的内容来达到延时的目的。 3、利用vbs延迟函数,精确度毫秒,误差1000毫秒内 例: @echo off echo %time% call :delay 5000 echo %time% pause exit :delay echo WScript.Sleep %1>delay.vbs CScript //B delay.vbs del delay.vbs goto :eof 运行显示: 10:44:06.45 10:44:11.95 请按任意键继续. . . 上面的运行结果显示实际延时了5500毫秒,多出来的500毫秒时建立和删除临时文件所耗费的时间。误差在一秒之内。 4、仅用批处理命令实现任意时间延迟,精确度10毫秒,误差50毫秒内 仅用批处理命令就可以实现延迟操作。 例: @echo off set /p delay=请输入需延迟的毫秒数: set TotalTime=0 set NowTime=%time% ::读取起始时间,时间格式为:13:01:05.95 echo 程序开始时间:%NowTime% :delay_continue set /a minute1=1%NowTime:~3,2%-100 ::读取起始时间的分钟数 set /a second1=1%NowTime:~-5,2%%NowTime:~-2%0-100000 ::将起始时间的秒数转为毫秒 set NowTime=%time% set /a minute2=1%NowTime:~3,2%-100 :: 读取现在时间的分钟数 set /a second2=1%NowTime:~-5,2%%NowTime:~-2%0-100000 ::将现在时间的秒数转为毫秒 set /a TotalTime+=(%minute2%-%minute1%+60)%%60*60000+%second2%-%second1% if %TotalTime% lss %delay% goto delay_continue echo 程序结束时间:%time% echo 设定延迟时间:%delay%毫秒 echo 实际延迟时间:%TotalTime%毫秒 pause 运行显示: 请输入需延迟的毫秒数:6000 程序开始时间:15:32:16.37 程序结束时间:15:32:22.37 设定延迟时间:6000毫秒 实际延迟时间:6000毫秒 请按任意键继续. . . 实现原理:首先设定要延迟的毫秒数,然后用循环累加时间,直到累加时间大于等于延迟时间。 误差:windows系统时间只能精确到10毫秒,所以理论上有可能存在10毫秒误差。 经测试,当延迟时间大于500毫秒时,上面的延迟程序一般不存在误差。当延迟时间小于500毫秒时,可能有几十毫秒误差,为什么?因为延迟程序本身也是有运行时间的,同时系统时间只能精确到10毫秒。 为了方便引用,可将上面的例子改为子程序调用形式: @echo off echo 程序开始时间:%Time% call :delay 10 echo 实际延迟时间:%totaltime%毫秒 echo 程序结束时间:%time% pause exit ::-----------以下为延时子程序-------------------- :delay @echo off if "%1"=="" goto :eof set DelayTime=%1 set TotalTime=0 set NowTime=%time% ::读取起始时间,时间格式为:13:01:05.95 :delay_continue set /a minute1=1%NowTime:~3,2%-100 set /a second1=1%NowTime:~-5,2%%NowTime:~-2%0-100000 set NowTime=%time% set /a minute2=1%NowTime:~3,2%-100 set /a second2=1%NowTime:~-5,2%%NowTime:~-2%0-100000 set /a TotalTime+=(%minute2%-%minute1%+60)%%60*60000+%second2%-%second1% if %TotalTime% lss %DelayTime% goto delay_continue goto :eof 十、模拟进度条 下面给出一个模拟进度条的程序。如果将它运用在你自己的程序中,可以使你的程序更漂亮。 @echo off mode con cols=113 lines=15 &color 9f cls echo. echo 程序正在初始化. . . echo. echo ┌──────────────────────────────────────┐ set/p= ■ 运行 -> 输入cmd -> edit -> ctrl+p(意思是允许输入特殊字符)-> 按ctrl+a将会显示笑脸图案。 (如果要继续输入特殊字符请再次按ctrl+p,然后ctrl+某个字母) 以上是特殊字符的输入方法,选自[英雄]教程,很管用的。也就是用编辑程序edit输入特殊字符,然后保存为一文本文件,再在windows下打开此文件,复制其中的特殊符号即可。 一些简单的特殊符号可以在dos命令窗口直接输入,并用重定向保存为文本文件。 例: C:>ECHO ^G>temp.txt “^G”是用Ctrl+G或Alt+007输入,输入多个^G可以产生多声鸣响。 特殊字符的应用也很有意思,这里仅举一例:退格键 退格键表示删除左边的字符,此键不能在文档中正常输入,但可以通过edit编辑程序录入并复制出来。即“”。 利用退格键,可以设计闪烁文字效果 例:文字闪烁 @echo off :start set/p=床前明月光nul ::设置延迟时间 set /p a=



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3