找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 18382|回复: 3

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

[复制链接]
发表于 2010-12-1 14:54:28 | 显示全部楼层 |阅读模式
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 编辑 ]
 楼主| 发表于 2010-12-1 16:14:19 | 显示全部楼层
咋就没人搭理我呢?咋就没人搭理我呢?
发表于 2010-12-1 20:46:13 | 显示全部楼层
  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
复制代码
 楼主| 发表于 2010-12-1 22:14:18 | 显示全部楼层
谢谢楼上的。很好很强大。
再加一个logoff。嘿嘿。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-16 22:57 , Processed in 0.024466 second(s), 10 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表