用批处理读取特定注册表项的路径值
用批处理命令查询注册表项的命令为
REG QUERY ...
具体的使用信息在命令行窗口中输入
REG QUERY /?
在这里我们需要查询一个具体的key-value,则使用下面的命令
REG QUERY [REG PATH] /v [KEY]
举个例子
reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\110\Tools\ClientSetup" /v "Path"
显示结果如下:
D:\Work\学习文档\批处理>reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\110\Tools\ClientSetup" /v "Path" HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\110\Tools\ClientSetup Path REG_SZ C:\Program Files\Microsoft SQL Server\110\Tools\Binn\
我们要把红色的部分取出来,注意reg批处理命令这里的输出结果是两行,我们要取出来的是第二行的后半部分。我们用for 将这部分取出来。先来说一下for的基本结构:
for /f "tokens=1,2 delims=:" %%a in(‘REG QUERY [REG_PATH]') do ( set "value1=%%a" set "value2=%%b" )
for循环对REG QUERY取出的两行分别处理,取出的每行值保存在变量%%a中,但是这里使用了tokens 和delims,delims指定了分割字符串的字符,这里也就是用":"将每行字符串进行分割,tokens=1,2 表示取出分割之后的前两列,第一列保存在%%a中,第二列保存在%%b中(如果有第三列则保存在%%c中)。。。继续看上面的例子。
echo off for /f "tokens=1,2 delims=:" %%a in('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\110\Tools\ClientSetup" /v "Path"') do ( set "value1=%%a" echo %value1% set "value2=%%b" echo %value2% )
最终的变量值
value1 = Path REG_SZ C
value2 = \Program Files\Microsoft SQL Server\110\Tools\Binn\
将value1的倒数第一个字符(也就是盘符c)和value2连接起来,中间用 :
set "value2=%value1:~-1%:%value2%"
作者:
HarlanC
博客地址:
http://www.cnblogs.com/harlanc/
个人博客:
http://www.harlancn.me/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出,
原文链接