批处理命令学习笔记——Set命令
2016-12-08 13:32
453 查看
Set 命令
显示、设置或删除 cmd.exe 环境变量。
语法:
SET [variable=[string]]
SET [[/a [expression]] [/p [variable=]] string]
variable 指定环境变量名。string 指定要指派给变量的一系列字符串。
要显示当前环境变量,键入不带参数的 SET。
如果命令扩展名被启用,SET 会如下改变:
仅用一个变量名而不带等号或者值激活 SET 命令时,显示所有前缀与提供给SET命令相匹配的变量名及其值。例如:
SET P
会显示所有以字母 P 打头的变量。
如果在当前环境中找不到该变量名称,SET 命令将把 ERRORLEVEL设置成 1。
SET 命令不允许变量名含有等号。
在 SET 命令中添加了两个新命令行开关:
SET /A expression
SET /P variable=[promptString]
/A 命令行开关指定等号右边的字符串为被评估的数字表达式。该表达式评估器很简单并以递减的优先权顺序支持下列操作:
如果您使用任何逻辑或取余操作符, 您需要将表达式字符串用引号扩起来。在表达式中的任何非数字字符串将作为环境变量名称,这些环境变量名称的值已在使用前转换成数字。如果指定了一个环境变量名称,但未在当前环境中定义,那么值将被定为零。这使您可以使用环境变量值做计算而不用键入那些 % 符号来得到它们的值。如果 SET /A 在命令脚本外的命令行执行的,那么它显示该表达式的最后值。该分配的操作符在分配的操作符左边需要一个环境变量名称。除十六进制有 0x 前缀, 八进制有 0 前缀的,数字值为十进位数字。因此, 0x12
与 18 和 022相同。请注意八进制公式可能很容易搞混: 08 和 09 是无效的数字,因为 8 和 9 不是有效的八进制位数。
/P 命令行开关允许将变量数值设成用户输入的一行输入。读取输入行之前,显示指定的 promptString。promptString 可以是空的。
环境变量替换已如下增强:
下面这个例子比较全面地展示了 SET 命令的上述扩展功能:
延迟环境变量扩展
最后,添加了延迟环境变量扩展的支持。该支持总是按默认值被停用,但也可以通过 CMD.EXE 的 /V 命令行开关而被启用/停用。请参阅 CMD /?。
考虑到读取一行文本时所遇到的目前扩充的限制时,延迟环境变量扩充是很有用的,而不是执行的时候。以下例子说明直接变量扩充的问题:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "%VAR%" == "after" @echo If you see this, it worked
)
将不会显示期望的消息,因为在读到第一个 IF 语句时,BOTH IF 语句中的 %VAR% 会被代替;原因是: 它包含 IF 的文体,IF 是一个复合语句。所以,复合语句中的 IF 实际上是在比较 "before" 和"after",这两者永远不会相等。同样,以下这个例子也不会达到预期效果:
set LIST=
for %i in (*) do set LIST=%LIST% %i
echo %LIST%
原因是,它不会在目前的目录中建立一个文件列表,而只是将LIST 变量设成找到的最后一个文件。这也是因为 %LIST% 在FOR 语句被读取时,只被扩充了一次;而且,那时的 LIST 变量是空的。因此,我们真正执行的 FOR 循环是:
for %i in (*) do set LIST= %i
这个循环继续将 LIST 设成找到的最后一个文件。
延迟环境变量扩充允许您使用一个不同的字符(惊叹号)在执行时间扩充环境变量。如果延迟的变量扩充被启用,可以将上面例子写成以下所示,以达到预期效果:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "!VAR!" == "after" @echo If you see this, it worked
)
set LIST=
for %i in (*) do set LIST=!LIST! %i
Echo %LIST%
自动变量
如果命令扩展名被启用,有几个动态环境变量可以被扩展,但不会出现在 SET 显示的变量列表中。每次变量数值被扩展时,这些变量数值都会被动态计算。如果用户用这些名称中任何一个定义变量,那个定义会替代下面描述的动态定义:
显示、设置或删除 cmd.exe 环境变量。
语法:
SET [variable=[string]]
SET [[/a [expression]] [/p [variable=]] string]
variable 指定环境变量名。string 指定要指派给变量的一系列字符串。
要显示当前环境变量,键入不带参数的 SET。
如果命令扩展名被启用,SET 会如下改变:
仅用一个变量名而不带等号或者值激活 SET 命令时,显示所有前缀与提供给SET命令相匹配的变量名及其值。例如:
SET P
会显示所有以字母 P 打头的变量。
如果在当前环境中找不到该变量名称,SET 命令将把 ERRORLEVEL设置成 1。
SET 命令不允许变量名含有等号。
在 SET 命令中添加了两个新命令行开关:
SET /A expression
SET /P variable=[promptString]
/A 命令行开关指定等号右边的字符串为被评估的数字表达式。该表达式评估器很简单并以递减的优先权顺序支持下列操作:
运算符 | 执行的操作 |
---|---|
() | 分组 |
! ~ - | 一元运算符 |
* / % | 算术运算符 |
+ - | 算术运算符 |
<< >> | 逻辑移位 |
& | 按位“与”运算 |
^ | 按位“异或”运算 |
| | 按位“或”运算 |
= *= /= %= += -= &= ^= |= <<= >>= | 赋值 |
, | 表达式分隔符 |
与 18 和 022相同。请注意八进制公式可能很容易搞混: 08 和 09 是无效的数字,因为 8 和 9 不是有效的八进制位数。
/P 命令行开关允许将变量数值设成用户输入的一行输入。读取输入行之前,显示指定的 promptString。promptString 可以是空的。
环境变量替换已如下增强:
%PATH:str1=str2% | 会扩展 PATH 环境变量,用"str2"代替扩展结果中的每个"str1"。要有效地从扩展结果中删除所有的"str1","str2"可以是空的。"str1"可以以星号打头;在这种情况下,"str1"会从扩展结果的开始到 str1 剩余部分第一次出现的地方,都一直保持相配。也可以为扩展名指定子字符串。 |
%PATH:~10,5% | 会扩展 PATH 环境变量,然后只使用在扩展结果中从第 11 个(偏移量 10)字符开始的五个字符。如果没有指定长度,则采用默认值,即变量数值的余数。如果两个数字(偏移量和长度)都是负数,使用的数字则是环境变量数值长度加上指定的偏移量或长度。 |
%PATH:~-10% | 会提取 PATH 变量的最后十个字符。 |
%PATH:~0,-2% | 会提取 PATH 变量的所有字符,除了最后两个。 |
set | 显示目前所有可用的变量,包括系统变量和自定义的变量 |
echo %SystemDrive% | 显示系统盘盘符。系统变量可以直接引用 |
set p | 显示所有以p开头的变量,要是一个也没有就设errorlevel=1 |
set p=aa1bb1aa2bb2 | 设置变量p,并赋值为 = 后面的字符串,即aa1bb1aa2bb2 |
echo %p% | 显示变量p代表的字符串,即aa1bb1aa2bb2 |
echo %p:~6% | 显示变量p中第6个字符以后的所有字符,即aa2bb2 |
echo %p:~6,3% | 显示第6个字符以后的3个字符,即aa2 |
echo %p:~0,3% | 显示前3个字符,即aa1 |
echo %p:~-2% | 显示最后面的2个字符,即b2 |
echo %p:~0,-2% | 显示除了最后2个字符以外的其它字符,即aa1bb1aa2b |
echo %p:aa=c% | 用c替换变量p中所有的aa,即显示c1bb1c2bb2 |
echo %p:aa=% | 将变量p中的所有aa字符串置换为空,即显示1bb12bb2 |
echo %p:*bb=c% | 第一个bb及其之前的所有字符被替换为c,即显示c1aa2bb2 |
set p=%p:*bb=c% | 设置变量p,赋值为 %p:*bb=c% ,即c1aa2bb2 |
set /a p=39 | 设置p为数值型变量,值为39 |
set /a p=39/10 | 支持运算符,有小数时用去尾法,39/10=3.9,去尾得3,p=3 |
set /a p=p/10 | 用 /a 参数时,在 = 后面的变量可以不加%直接引用 |
set /a p="1&0" | "与"运算,要加引号。其它支持的运算符参见set/? |
set p= | 取消p变量 |
set /p p=请输入 | 屏幕上显示"请输入",并会将输入的字符串赋值给变量p注意这条可以用来取代 choice 命令 |
最后,添加了延迟环境变量扩展的支持。该支持总是按默认值被停用,但也可以通过 CMD.EXE 的 /V 命令行开关而被启用/停用。请参阅 CMD /?。
考虑到读取一行文本时所遇到的目前扩充的限制时,延迟环境变量扩充是很有用的,而不是执行的时候。以下例子说明直接变量扩充的问题:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "%VAR%" == "after" @echo If you see this, it worked
)
将不会显示期望的消息,因为在读到第一个 IF 语句时,BOTH IF 语句中的 %VAR% 会被代替;原因是: 它包含 IF 的文体,IF 是一个复合语句。所以,复合语句中的 IF 实际上是在比较 "before" 和"after",这两者永远不会相等。同样,以下这个例子也不会达到预期效果:
set LIST=
for %i in (*) do set LIST=%LIST% %i
echo %LIST%
原因是,它不会在目前的目录中建立一个文件列表,而只是将LIST 变量设成找到的最后一个文件。这也是因为 %LIST% 在FOR 语句被读取时,只被扩充了一次;而且,那时的 LIST 变量是空的。因此,我们真正执行的 FOR 循环是:
for %i in (*) do set LIST= %i
这个循环继续将 LIST 设成找到的最后一个文件。
延迟环境变量扩充允许您使用一个不同的字符(惊叹号)在执行时间扩充环境变量。如果延迟的变量扩充被启用,可以将上面例子写成以下所示,以达到预期效果:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "!VAR!" == "after" @echo If you see this, it worked
)
set LIST=
for %i in (*) do set LIST=!LIST! %i
Echo %LIST%
自动变量
如果命令扩展名被启用,有几个动态环境变量可以被扩展,但不会出现在 SET 显示的变量列表中。每次变量数值被扩展时,这些变量数值都会被动态计算。如果用户用这些名称中任何一个定义变量,那个定义会替代下面描述的动态定义:
自动变量 | 说明 |
---|---|
%CD% | 扩展到当前目录字符串。 |
%DATE% | 用跟 DATE 命令同样的格式扩展到当前日期。 |
%TIME% | 用跟 TIME 命令同样的格式扩展到当前时间。 |
%RANDOM% | 扩展到 0 和 32767 之间的任意十进制数字。 |
%ERRORLEVEL% | 扩展到当前 ERRORLEVEL 数值。 |
%CMDEXTVERSION% | 扩展到当前命令处理器扩展名版本号。 |
%CMDCMDLINE% | 扩展到调用命令处理器的原始命令行。 |
相关文章推荐
- 批处理命令学习笔记——简单的批处理应用实例
- 【批处理学习笔记】第四课:简单批处理命令(3)
- 批处理命令学习笔记——删除系统默认共享
- 【批处理学习笔记】第二课:简单批处理命令(1)
- 【批处理学习笔记】第十三课:常用dos命令(3)
- Hadoop学习笔记-004-CentOS_6.5_64_批处理命令脚本
- 【批处理学习笔记】第三课:简单批处理命令(2)
- 【批处理学习笔记】第十一课:常用DOS命令(1)
- 【批处理学习笔记】第十四课:常用DOS命令(4)
- 学习笔记:dos控制台下用set命令设置classpath临时变量分号问题
- 【批处理学习笔记】第七课:简单的批处理命令(6)
- 【批处理学习笔记】第五课:简单的批处理命令(4)
- 批处理命令学习笔记——参数处理
- 【批处理学习笔记】第六课:简单的批处理命令(5)
- 批处理学习笔记9 - 深入学习For命令2
- Set 命令集学习
- 设计模式学习笔记(十七)——Command命令模式
- ARM学习笔记---linux基本命令
- Linux学习笔记13--使用mount命令挂载CDROM
- Linux学习笔记9--touch命令使用