我正在尝试使用Python中的WinReg,但我面临着一个障碍。下面的代码应该为每个返回的条目返回一个带有键:value的字典,我发现自己得到了相同的键:value。
如何编辑这段代码以获得不同的值或值?
import _winreg
def subkeys(key):
i = 0
while True:
try:
subkey = _winreg.EnumKey(key, i)
yield subkey
i+=1
except WindowsError as e:
break
def traverse_registry_tree(hkey, keypath, tabs=0):
reg_dict = {}
key = _winreg.OpenKey(hkey, keypath, 0, _winreg.KEY_READ)
for subkeyname in subkeys(key):
reg_dict[subkeyname] = subkeyname
return reg_dict
keypath = r"SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall"
print traverse_registry_tree(_winreg.HKEY_LOCAL_MACHINE, keypath)输出与此类似:
{'Mozilla Firefox 40.0.2 (x86 en-US)': 'Mozilla Firefox 40.0.2 (x86 en-US)', 'IE40': 'IE40', 'Connection Manager': 'Connection Manager'}任何帮助都会感激的,请记住我不是一个先进的侏儒。
发布于 2015-08-24 07:07:07
每次您在traverse_registry_tree函数中递归时,都会创建一个新的字典。所以每本字典里只有一个键。
您可以判断这是错误的,因为在递归调用中,您不会对返回值做任何事情:外部调用打印返回,而内部调用没有。
您可以通过将递归调用的返回值打包到正在创建的字典中来修复这个问题。但是,这并不像在递归调用中来回传递整个字典那样有效:
def traverse_registry_tree(hkey, keypath, reg_dict):
key = _winreg.OpenKey(hkey, keypath, 0, _winreg.KEY_READ)
reg_dict[keypath] = key
for subkey in subkeys(key):
subkeypath = "%s\\%s" % (keypath, subkey)
traverse_registry_tree(hkey, subkeypath, reg_dict)
reg_dict = {}
keypath = r"SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall"
traverse_registry_tree(_winreg.HKEY_LOCAL_MACHINE, keypath, reg_dict)
print(reg_dict)不确定您是否也在询问如何访问注册表值(以及键)?如果是这样的话,下面也有一些代码可以这样做:
def get_values(key):
key_dict = {}
i = 0
while True:
try:
subvalue = _winreg.EnumValue(key, i)
except WindowsError as e:
break
key_dict[subvalue[0]] = subvalue[1:]
i+=1
return key_dict
def traverse_registry_tree(hkey, keypath, reg_dict):
key = _winreg.OpenKey(hkey, keypath, 0, _winreg.KEY_READ)
reg_dict[keypath] = get_values(key)
for subkey in subkeys(key):
subkeypath = "%s\\%s" % (keypath, subkey)
traverse_registry_tree(hkey, subkeypath, reg_dict)https://stackoverflow.com/questions/32171448
复制相似问题