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

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

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

 

  

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值