Fork me on GitHub

用批处理读取特定注册表项的路径值

用批处理命令查询注册表项的命令为

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%"

 

  

 

posted @ 2016-07-09 21:48  HarlanC  阅读(7922)  评论(0编辑  收藏  举报