[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[注册表类] 批处理怎样根据硬件ID查reg对应项字符串并以字符串查class位置?

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USB\Vid_13fe&Pid_1d00\033591D0]
"Driver"="{36FC9E60-C465-11CF-8056-444553540000}\\0015"

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Class\{36FC9E60-C465-11CF-8056-444553540000}\0015]
"NonRemovable"=dword:00000001

这是我要查询和修改的注册表。
因为我想隐藏右下角任务栏的USB图标。但是每一款USB设备的硬件ID都不一样。

Driver和Class后面的值在注册表里面是一样的。
假如我的USB设备的ID是Vid_13fe&Pid_1d00\033591D0

运行批处理。
手工输入
USB硬件ID(假设现在是Vid_13fe&Pid_1d00\033591D0),回车。

批处理根据ID到批处理指定路径去查询
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USB\硬件ID]
并读取它下面的Driver子键参数
"Driver"="
读取值"

根据所读取的参数生成
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Class\
读取值]      
"NonRemovable"=dword:00000001

regedit /s写入。
再然后logoff。


多余说一句。那driver后面的那个0015前面好像多了一条下划线。我导出来就是这样。不知道有没有区别。
如果有兄弟愿意帮忙的话,希望能多余写下注释。这样下次碰到有类似读取需求的时候,我就可以举一反三了。

[ 本帖最后由 seetop7 于 2010-12-1 17:39 编辑 ]

咋就没人搭理我呢?咋就没人搭理我呢?

TOP

  1. @echo off
  2. set/p "id=请输入"
  3. for /f "skip=4 tokens=2*" %%a in ('reg query "HKLM\SYSTEM\CurrentControlSet\Enum\USB\%id%" /v Driver') do reg add "HKLM\SYSTEM\CurrentControlSet\Control\Class\%%b" /v NonRemovable /d 1 /t REG_DWORD /f
复制代码
寒夜孤星:在没有说明的情况下,本人所有代码均运行在 XP SP3 下 (有问题请发贴,QQ临时会话已关闭)

TOP

谢谢楼上的。很好很强大。
再加一个logoff。嘿嘿。

TOP

返回列表